回答編集履歴

1

コンポーネントを分割する方法

2018/02/28 06:27

投稿

KazuyaGosho
KazuyaGosho

スコア38

test CHANGED
@@ -81,3 +81,83 @@
81
81
 
82
82
 
83
83
  これで問題なく動いたので使ってますが、知見がある方のご意見も頂けたら嬉しく思います。
84
+
85
+
86
+
87
+ [追記]
88
+
89
+
90
+
91
+ この書き方は良くなかったかもしれません。ESLintには引っかからないですが、アロー関数を直接渡すのと同様、パフォーマンスには影響あるかもです。
92
+
93
+ 考えてみれば、アロー関数を返す関数を渡しているだけなので・・・
94
+
95
+
96
+
97
+ 新しいコンポーネントを作成してそれに流し込むのが良いのでしょうね
98
+
99
+
100
+
101
+ ```java
102
+
103
+ class MyButton extends Component {
104
+
105
+ constructor(props) {
106
+
107
+ super(props);
108
+
109
+ this.onClick = this.onClick.bind(this);
110
+
111
+ }
112
+
113
+
114
+
115
+ onClick(event) {
116
+
117
+ this.props.onClick(event);
118
+
119
+ }
120
+
121
+
122
+
123
+ render() {
124
+
125
+ return <button item={this.props.item} onClick={this.onClick} />
126
+
127
+ }
128
+
129
+ }
130
+
131
+
132
+
133
+ class Sample extends Component {
134
+
135
+ // 略
136
+
137
+
138
+
139
+ render() {
140
+
141
+ return (
142
+
143
+ <div>
144
+
145
+ {this.state.data.map(item =>
146
+
147
+ <MyButton item={item} onClick={this.onClick} />
148
+
149
+ )}
150
+
151
+ </div>
152
+
153
+ );
154
+
155
+ }
156
+
157
+
158
+
159
+ // 略
160
+
161
+ }
162
+
163
+ ```