質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

2回答

1087閲覧

Reactでバインドはなぜ必要なのか?

退会済みユーザー

退会済みユーザー

総合スコア0

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

1グッド

2クリップ

投稿2020/03/15 01:54

編集2020/03/15 01:56

https://ja.reactjs.org/docs/faq-functions.html の記事に下記記述があります。

そもそもバインドはなぜ必要なのか? JavaScript において、以下の 2 つのコードは同等 ではありません。 (1) obj.method(); (2) var method = obj.method; method(); メソッドはバインドすることで、2 つ目のコードが 1 つ目と同様に動作するようになります。

その記事を読んだ感じだと2つのコードが同等ではない理由がわかりませんでした。
この違いはreact特有なのでしょうか?解説をお願いします。

s.k👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

この違いはreact特有なのでしょうか?

いえ、JavaScript全般に共通するものです。JavaScriptの関数・メソッド内ではthisという値が使えますが、このthisは、bindやArrow Functionを除けば呼び出し方によって変化しえます(MDN)。

  • obj.method();の場合→thisobj
  • いったんmethodに代入した場合→thisはグローバルオブジェクトもしくはundefined

通常、メソッドを呼び出す際には正しいthisが必要ですので、事前にバインドする、もしくはArrow Functionで定義することとなります。

投稿2020/03/15 02:03

maisumakun

総合スコア146018

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

this(メソッドのレシーバー)が何を示すかが変わります。

JavaScript

1const obj = { 2 "aaa": 123, 3 "method": function(){ console.log(this); } 4} 5 6obj.method(); 7 8console.log("-----------------------------"); 9 10const method = obj.method; 11method();

投稿2020/03/15 02:13

otn

総合スコア85901

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問