我開始實施,其中「啞巴」組件對此一無所知的環境,並通過接收所有道具它的數據的智能/啞組件模式。當啞組件必須提交或更改數據時,您會做什麼?它如何與外界溝通,仍然是「愚蠢的」?反應智能/啞組件模式更改數據
這是我用來判斷這個模式的基本例子。如果我將事件添加到更新數據庫中的計數器的MyTask
組件中,那麼會處理該事件?
// components/MyList.jsx
import React from 'react';
export default class MyList extends React.Component {
render() {
return(
<div>
<h3>{this.props.listName}</h3>
<ul>
{this.props.tasks.map((task) => (
<MyTask key={task.id} task={task} />
))}
</ul>
</div>
);
}
}
MyList.propTypes = {
listName: React.PropTypes.string.isRequired,
tasks: React.PropTypes.array.isRequired,
}
export class MyTask extends React.Component {
render() {
return (
<li>{this.props.task.text}</li>
);
}
}
MyTask.propTypes = {
task: React.PropTypes.object.isRequired,
}
和應用程序:
// app.jsx
import React from 'react';
import MyList from './components/MyList.jsx'
export class TaskApp extends React.Component {
getList() {
return('Today Stuff');
}
getTasks() {
return([
{id: 1, text: 'foo'},
{id: 2, text: 'diggity'},
{id: 3, text: 'boo'},
{id: 4, text: 'bop'}
]);
}
render() {
return (
<MyList listName={this.getList()} tasks={this.getTasks()} />
);
}
}
接受的答案在解釋中稍微冗長一些。謝謝! – Scott
你可以舉個例子說明'this'這兩個不同的綁定嗎?這將是一個非常徹底的答案,增加。 – Scott
向答案添加了一些額外的綁定上下文示例。乾杯! –