ionic3 cordova-plugin-facebook4 facebook安装发出错误

phi*_*son 3 facebook ionic-framework ionic3 angular

我似乎遇到了本机插件的问题.

logPath:/Users/philipwilson/workspace/ionic/test2/platforms/ios/cordova/console.log

        [21:12:05]  console.log: Angular is running in the development mode. Call enableProdMode() to enable the production 
                    mode. 
        [21:12:05]  console.log: Ionic Native: deviceready event fired after 542 ms 
        [21:12:05]  console.warn: Native: tried calling Facebook.browserInit, but the Facebook plugin is not installed. 
        [21:12:05]  console.warn: Install the Facebook plugin: 'ionic plugin add cordova-plugin-facebook4' 
Run Code Online (Sandbox Code Playgroud)

我尝试过很多东西.

 518  ionic cordova plugin add cordova-plugin-facebook4 --variable APP_ID="99999999999" --variable APP_NAME="test2.com"
 565  ionic cordova build ios
 578  npm install --save @ionic-native/facebook
 593  ionic plugin add cordova-plugin-facebook4
 594  ionic cordova emulate ios -lc
Run Code Online (Sandbox Code Playgroud)

我按照几个例子,但仍然看到离子3和angular4的问题

这是我的信息:〜/ workspace/ionic/test2 $ ionic info

全球套餐:

@ionic/cli-utils : 1.5.0
Cordova CLI      : 7.0.1 
Ionic CLI        : 3.5.0
Run Code Online (Sandbox Code Playgroud)

本地包裹:

@ionic/app-scripts              : 1.3.7
@ionic/cli-plugin-cordova       : 1.4.1
@ionic/cli-plugin-ionic-angular : 1.3.2
Cordova Platforms               : ios 4.4.0
Ionic Framework                 : ionic-angular 3.4.2
Run Code Online (Sandbox Code Playgroud)

系统:

Node       : v8.0.0
OS         : OS X El Capitan
Xcode      : Xcode 8.2.1 Build version 8C1002 
ios-deploy : 1.8.3 
ios-sim    : 3.1.1 
npm        : 5.0.0 
Run Code Online (Sandbox Code Playgroud)

安装插件

用ios lc运行

使用run ios进行测试时出错 我也看过这些例子:https : //ionicframework.com/docs/native/facebook/ https://ionicthemes.com/tutorials/about/ionic2-facebook-login

有人帮忙吗?

谢谢菲尔

may*_*ito 5

这就是我所做的,确保你在你的app.module.ts文件上公开Facebook模块.

app.module.ts

import { NgModule, ErrorHandler } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { IonicApp, IonicModule, IonicErrorHandler } from 'ionic-angular';
import { MyApp } from './app.component';

import { AboutPage } from '../pages/about/about';
import { ContactPage } from '../pages/contact/contact';
import { HomePage } from '../pages/home/home';
import { TabsPage } from '../pages/tabs/tabs';

import { StatusBar } from '@ionic-native/status-bar';
import { SplashScreen } from '@ionic-native/splash-screen';

import { Facebook, FacebookLoginResponse } from '@ionic-native/facebook';

@NgModule({
  declarations: [
    MyApp,
    AboutPage,
    ContactPage,
    HomePage,
    TabsPage
  ],
  imports: [
    BrowserModule,
    IonicModule.forRoot(MyApp)
  ],
  bootstrap: [IonicApp],
  entryComponents: [
    MyApp,
    AboutPage,
    ContactPage,
    HomePage,
    TabsPage
  ],
  providers: [
    StatusBar,
    SplashScreen,
    Facebook,
    {provide: ErrorHandler, useClass: IonicErrorHandler}
  ]
})
export class AppModule {}
Run Code Online (Sandbox Code Playgroud)

在你的home.ts:

import { Component } from '@angular/core';
import { NavController } from 'ionic-angular';
import { Facebook, FacebookLoginResponse } from '@ionic-native/facebook';

@Component({
  selector: 'page-home',
  templateUrl: 'home.html'
})
export class HomePage {

  constructor(public navCtrl: NavController, private fb: Facebook) {
    this.fb = fb

    console.log(fb)

    this.fb.login(['public_profile', 'user_friends', 'email'])
      .then((res: FacebookLoginResponse) => 
        console.log('Logged into Facebook!', res)
      )
      .catch(e => console.log('Error logging into Facebook', e));


    this.fb.logEvent(this.fb.EVENTS.EVENT_NAME_ADDED_TO_CART);
  }

}
Run Code Online (Sandbox Code Playgroud)

如果您忘记了包含Facebook提供商的app.module.ts文件,您将收到错误消息:"No provider for Facebook!"

作为旁注,请确保使用模拟器或设备来测试登录操作,否则它将无法工作.

资源: - https://javebratt.com/ionic-2-facebook-login/ - https://ionicframework.com/docs/native/facebook/