ReactJS、NodeJS、Webpack、およびFacebook SDKを使用してユーザー認証を開始しています。これらのテクノロジとそれに関連するソフトウェアエンジニアリングの原則/ベストプラクティスはすべて私には比較的新しいものです(JavaScriptでもかなり新しくなっています)。Facebook Web SDKとReactJSの統合コンポーネントの状態
ここではチュートリアルhttps://developers.facebook.com/docs/facebook-login/webに従っています。私はFacebook認証がうまくいっています!しかし、このチュートリアルのコンテンツは構造化されているので、FBステータスレスポンスハンドラが生のページHTMLの<body>
タグの中だけに含まれることを期待するように設計されているようです。以下は特にこれを参照しています:
// Load the SDK asynchronously
(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'));
この戦略では、私はリアクションコンポーネントとの統合が不完全で困難です。 Facebookのログイン/認証コードとFacebookステータス更新ハンドラをHTMLから再配置する方法はありますか?たとえば、Webpack経由でReactコードにバンドルされているスクリプトに?出来ますか?私の質問の理由の一部は、Facebookの状態更新ハンドラが自分のReactコンポーネントの状態を更新できるように正しく理解していれば、そのハンドラは関連するReactコンポーネントへのアクセスを持つコンポーネントの一部でなければならないということです。this.setState(...)
関数。
私はこれについて正しく考えていますか?
FBの定義に誤りがありますか? –
@JeffTian 'FB.'の代わりに' window.FB.'を使うと、定義されていないエラーを解決するはずです。 – Kilpatrick