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

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

新規登録して質問してみよう
ただいま回答率
85.48%
ESLint

ESLintは、JavaScriptのための構文チェックツール。全検証ルールを自由に on/offでき、独自のプロジェクトに合わせたカスタムルールを容易に設定することが可能。公開されている様々なプラグインを組み込んで使用することもできます。

React.js

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

Q&A

解決済

2回答

6247閲覧

ESlint で jsx-no-bind を守るには?

退会済みユーザー

退会済みユーザー

総合スコア0

ESLint

ESLintは、JavaScriptのための構文チェックツール。全検証ルールを自由に on/offでき、独自のプロジェクトに合わせたカスタムルールを容易に設定することが可能。公開されている様々なプラグインを組み込んで使用することもできます。

React.js

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

0グッド

0クリップ

投稿2016/06/23 02:16

編集2016/06/23 02:19

不明点

ESlintのルールの一つとして,jsx-no-bind があります.これはjsx内でのbindを禁止するものですが,同時にjsx内でのarrow-functionの利用も禁止します.
私が愛用している,eslint-plugin である eslint-config-airbnbには,jsx-no-bind が 2 (エラー出力)で入っています.

jsx内でbind してはいけない,あるいはアローファンクションを定義しては行けない理由はわかります.
なぜならば,render() されるたびに関数が生成され,メモリリークの危険性があるからです.

そこで,インスタンスメソッドとして event に登録する関数を定義すれば良いのですが,一つ不明点がでてきました.

それは,イベントに引数を付与したい時です.具体的には次のようなコンポーネントです.

js

1 2class Sample extends React.Component { 3 constructor(props) { 4 super(props); 5 this.state = { 6 data: [ 7 1, 8 2, 9 3, 10 4, 11 ], 12 }; 13 this.renderButtonList = this.renderBurronList.bind(this); 14 } 15 16 renderButtonList() { 17 return this.state.data.map(item => { 18 return ( 19 <button 20 onClick={(e) => this.onClick(e, item)} 21 /> 22 ); 23 }); 24 } 25 26 render() { 27 return ( 28 <div> 29 {this.renderBurronList()} 30 </div> 31 ); 32 } 33}

あまり望まない回答

  • jsx-no-bind を 1 にする.(逃げてる感じがするので)
  • ここだけコメント文でルールを無効化する

lint ルール は必ず守らなくちゃいけないとは思ってなく,必要に応じては上書きして無効化するのも視野に入れていますが,質問の回答としてはあまり望んでいません.

上のようなコードを arrow-function なしでかつ 直感的に書く方法が知りたいからです.

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

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

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

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

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

guest

回答2

0

ES6の機能ですが、これはどうでしょうか?

js

1class Sample extends React.Component { 2 constructor(props) { 3 super(props); 4 this.state = { 5 data: [ 6 1, 7 2, 8 3, 9 4, 10 ], 11 }; 12 } 13 14 onClick = (item) => (e) => { 15 // 押下時の挙動 16 } 17 18 renderButtonList() { 19 return this.state.data.map(item => { 20 return ( 21 <button 22 onClick={this.onClick(item)} 23 /> 24 ); 25 }); 26 } 27 28 render() { 29 return ( 30 <div> 31 {this.renderBurronList()} 32 </div> 33 ); 34 } 35} 36

これで問題なく動いたので使ってますが、知見がある方のご意見も頂けたら嬉しく思います。

[追記]

この書き方は良くなかったかもしれません。ESLintには引っかからないですが、アロー関数を直接渡すのと同様、パフォーマンスには影響あるかもです。
考えてみれば、アロー関数を返す関数を渡しているだけなので・・・

新しいコンポーネントを作成してそれに流し込むのが良いのでしょうね

java

1class MyButton extends Component { 2 constructor(props) { 3 super(props); 4 this.onClick = this.onClick.bind(this); 5 } 6 7 onClick(event) { 8 this.props.onClick(event); 9 } 10 11 render() { 12 return <button item={this.props.item} onClick={this.onClick} /> 13 } 14} 15 16class Sample extends Component { 17 // 略 18 19 render() { 20 return ( 21 <div> 22 {this.state.data.map(item => 23 <MyButton item={item} onClick={this.onClick} /> 24 )} 25 </div> 26 ); 27 } 28 29 // 略 30}

投稿2018/02/28 05:10

編集2018/02/28 06:27
KazuyaGosho

総合スコア38

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

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

guest

0

ベストアンサー

例えば、要素自体にデータを持たせる方法があります。
HTML要素であれば、data-*属性に情報を保存することができます。

jsx

1 return this.state.data.map(item => { 2 return ( 3 <button 4 data-item={item} 5 onClick={this.onClick} 6 /> 7 ); 8 });

投稿2016/10/08 14:58

編集2016/10/08 15:00
mysticatea

総合スコア30

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

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

退会済みユーザー

退会済みユーザー

2016/10/11 03:02

なるほど.これは知らなかったです.文字列や数値であればこの方法で解決できそうです.
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問