我开始实施,其中“哑巴”组件对此一无所知的环境,并通过接收所有道具它的数据的智能/哑组件模式。当哑组件必须提交或更改数据时,您会做什么?它如何与外界沟通,仍然是“愚蠢的”?反应智能/哑组件模式更改数据
这是我用来判断这个模式的基本例子。如果我将事件添加到更新数据库中的计数器的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
向答案添加了一些额外的绑定上下文示例。干杯! –