آموزش فیس بوک در برنامه نویسی آیونیک
آموزش فیس بوک در برنامه نویسی آیونیک
در این درس از مجموعه آموزش برنامه نویسی سایت سورس باران، به آموزش فیس بوک در برنامه نویسی آیونیک خواهیم پرداخت.
این افزونه برای اتصال به Facebook API استفاده می شود. قبل از شروع ادغام فیس بوک ، باید یک برنامه فیس بوک در اینجا ایجاد کنید. شما یک برنامه وب ایجاد خواهید کرد و سپس از صفحه شروع سریع رد می شوید. سپس، باید بستر وب سایت را در صفحه تنظیمات اضافه کنید. در حین توسعه می توانید از قطعه کد زیر برای URL سایت استفاده کنید.
1 |
http://localhost:8100/ |
پس از آن ، باید URI های هدایت OAuth معتبر را در صفحه تنظیمات / پیشرفته اضافه کنید. فقط دو URL زیر را کپی کنید.
1 2 |
https://www.facebook.com/connect/login_success.html http: // localhost: 8100 / oauthcallback.html |
نصب پلاگین Facebook
ما برای حل برخی از مواردی که اغلب هنگام استفاده از این افزونه ظاهر می شوند، تمام مراحل بالا را انجام دادیم. راه اندازی این افزونه دشوار است زیرا مراحل زیادی در این زمینه وجود دارد و اسناد و مدارک همه آنها را پوشش نمی دهد. همچنین برخی از مشکلات سازگاری با سایر افزونه های Cordova شناخته شده است، بنابراین ما از نسخه پلاگین تأیید شده Teleric در برنامه خود استفاده خواهیم کرد. ما با نصب بستر مرورگر در برنامه خود از خط فرمان شروع خواهیم کرد.
1 |
C: \ Users \ Username \ Desktop \ MyApp> ionic platform browser add browser |
در مرحله بعد، آنچه باید انجام دهیم این است که عنصر ریشه را در بالای برچسب body در index.html اضافه کنیم.
index.html
1 |
<div id = "fb-root"></div> |
اکنون ما افزونه Cordova Facebook را به برنامه خود اضافه خواهیم کرد. برای مطابقت با برنامه فیس بوکی که قبلاً ایجاد کرده اید ، باید APP_ID و APP_NAME را تغییر دهید.
1 2 3 |
C:\Users\Username\Desktop\MyApp>cordova -d plugin add https://github.com/Telerik-Verified-Plugins/Facebook/ --variable APP_ID = "123456789" --variable APP_NAME = "FbAppName" |
حالا index.html را باز کنید و کد زیر را بعد از برچسب بدن خود اضافه کنید. باز هم باید مطمئن شوید که appId و نسخه با برنامه فیس بوکی که ایجاد کرده اید مطابقت دارند. با این کار بارگیری همزمان SDK فیس بوک بدون مسدود کردن بقیه برنامه ها تضمین می شود.
index.html
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
<script> window.fbAsyncInit = function() { FB.init({ appId : '123456789', xfbml : true, version : 'v2.4' }); }; (function(d, s, id) { var js, fjs = d.getElementsByTagName(s)[0]; if (d.getElementById(id)) {return;} js = d.createElement(s); js.id = id; js.src = "//connect.facebook.net/en_US/sdk.js"; fjs.parentNode.insertBefore(js, fjs); }(document, 'script', 'facebook-jssdk')); </script> |
سرویس انگولار
از آنجا که همه موارد را نصب کردیم ، باید خدماتی ایجاد کنیم که ارتباط ما با فیس بوک باشد. این کارها را می توان با کد کمتری در کنترلر انجام داد ، اما ما سعی می کنیم بهترین روش ها را دنبال کنیم ، بنابراین از سرویس Angular استفاده خواهیم کرد. کد زیر کل سرویس را نشان می دهد. بعداً توضیح خواهیم داد.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
.service('Auth', function($q, $ionicLoading) { this.getLoginStatus = function() { var defer = $q.defer(); FB.getLoginStatus(function(response) { if (response.status === "connected") { console.log(JSON.stringify(response)); } else { console.log("Not logged in"); } }); return defer.promise; } this.loginFacebook = function() { var defer = $q.defer(); FB.login(function(response) { if (response.status === "connected") { console.log(JSON.stringify(response)); } else { console.log("Not logged in!"); } }); return defer.promise; } this.logoutFacebook = function() { var defer = $q.defer(); FB.logout(function(response) { console.log('You are logged out!'); }); return defer.promise; } this.getFacebookApi = function() { var defer = $q.defer(); FB.api("me/?fields = id,email", [], function(response) { if (response.error) { console.log(JSON.stringify(response.error)); } else { console.log(JSON.stringify(response)); } }); return defer.promise; } }); |
در سرویس فوق، ما در حال ایجاد چهار تابع هستیم. سه مورد اول خود توضیحی هستند. تابع چهارم برای اتصال به API نمودار Facebook استفاده می شود. شناسه و ایمیل کاربر فیس بوک را برمی گرداند.
ما در حال ایجاد اشیا promise برای مدیریت توابع JavaScript غیر همزمان هستیم. اکنون باید کنترل کننده خود را بنویسیم که این توابع را فراخوانی کند. برای درک بهتر هر عملکرد را جداگانه فراخوانی خواهیم کرد ، اما احتمالاً لازم است برخی از آنها را با هم مخلوط کنید تا جلوه مورد نظر را بدست آورید.
کد کنترل کننده
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
.controller('MyCtrl', function($scope, Auth, $ionicLoading) { $scope.checkLoginStatus = function() { getLoginUserStatus(); } $scope.loginFacebook = function(userData) { loginFacebookUser(); }; $scope.facebookAPI = function() { getFacebookUserApi(); } $scope.logoutFacebook = function() { logoutFacebookUser(); }; function loginFacebookUser() { return Auth.loginFacebook(); } function logoutFacebookUser() { return Auth.logoutFacebook(); } function getFacebookUserApi() { return Auth.getFacebookApi(); } function getLoginUserStatus() { return Auth.getLoginStatus(); } }) |
احتمالاً از خود می پرسید که چرا ما سرویس Auth را مستقیماً از عبارات تابع (چهار تابع اول) برنگرداندیم. دلیل این امر این است که احتمالاً بعد از بازگشت تابع Auth می خواهید رفتار دیگری نیز به آن اضافه کنید. ممکن است برخی از داده ها را به پایگاه داده خود بفرستید ، مسیر را پس از ورود به سیستم تغییر دهید و غیره. این کار به راحتی با استفاده از روش ()JavaScript then انجام می شود تا تمام عملیات ناهمزمان به جای برگشت تماس انجام شود.
اکنون باید به کاربران اجازه دهیم با برنامه ارتباط برقرار کنند. HTML ما شامل چهار دکمه برای فراخوانی چهار عملکرد ایجاد شده است.
کد HTML
1 2 3 4 |
<button class = "button" ng-click = "loginFacebook()">LOG IN</button> <button class = "button" ng-click = "logoutFacebook()">LOG OUT</button> <button class = "button" ng-click = "checkLoginStatus()">CHECK</button> <button class = "button" ng-click = "facebookAPI()">API</button> |
وقتی کاربر روی دکمه LOG IN ضربه می زند، صفحه فیس بوک ظاهر می شود. پس از موفقیت در ورود به سیستم ، کاربر به برنامه هدایت می شود.
لیست جلسات قبل آموزش برنامه نویسی آیونیک
- آموزش برنامه نویسی آیونیک
- نگاهی کلی به آموزش برنامه نویسی آیونیک
- آموزش تنظیمات محیطی در برنامه نویسی آیونیک
- آموزش رنگ ها در برنامه نویسی آیونیک
- آموزش ایجاد محتوا در برنامه نویسی آیونیک
- آموزش هدر در برنامه نویسی آیونیک
- آموزش فوتر در برنامه نویسی آیونیک
- آموزش دکمه ها در برنامه نویسی آیونیک
- آموزش لیست ها در برنامه نویسی آیونیک
- آموزش کارت ها در برنامه نویسی آیونیک
- آموزش فرم ها در برنامه نویسی آیونیک
- آموزش Toggle در برنامه نویسی آیونیک
- آموزش چک باکس در برنامه نویسی آیونیک
- آموزش دکمه های رادیویی در برنامه نویسی آیونیک
- آموزش محدوده در برنامه نویسی آیونیک
- آموزش Select در برنامه نویسی آیونیک
- آموزش زبانه ها در برنامه نویسی آیونیک
- آموزش شبکه در برنامه نویسی آیونیک
- آموزش آیکون ها در برنامه نویسی آیونیک
- آموزش پدینگ در برنامه نویسی آیونیک
- آموزش صفحه اقدام جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش محتوای جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش فرم های جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش رویدادهای جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش هدر جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش فوتر جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش صفحه کلید جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش لیست جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش بارگذاری جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش Modal جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش پیمایش جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش Popover جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش پاپ آپ جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش پیمایش جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش منوی جانبی جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش جعبه اسلاید جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش تب های جاوا اسکریپت در برنامه نویسی آیونیک
- آموزش ادغام Cordova در برنامه نویسی آیونیک
- آموزش Cordova AdMob در برنامه نویسی آیونیک
- آموزش دوربین Cordova در برنامه نویسی آیونیک
دیدگاه شما