【发布时间】:2018-01-02 10:15:57
【问题描述】:
var gridWidth = 15;
var gridHeight = 15;
var grid = [];
for(var y=0; y<gridHeight; y++) {
grid.push([]);
for(var x=0; x<gridWidth; x++) {
grid[y][x] = {c:0};
}
}
var reducer = function(state = grid, action) {
let newState = clone(state);
if(action.type==='CC') {
newState[action.payload.y][action.payload.x].c = action.payload.c;
}
return newState;
}
var store = Redux.createStore(reducer);
var colours = ['black', 'grey'];
var Provider = ReactRedux.Provider;
var connect = ReactRedux.connect;
var map = function(state) {
return {grid:state};
}
var Box = React.createClass({
width: 15,
handleClick: function(x, y) {
this.props.dispatch({type:'CC', payload: {c:1, x:x, y:y}});
},
render: function() {
console.log('boxrender')
var pos = {
top: this.props.y * this.width,
left: this.props.x * this.width,
width: this.width,
height: this.width,
background: this.props.colours[this.props.box.c]
}
return <div className="box" style={pos} onMouseOver={() => this.handleClick(this.props.x, this.props.y)}></div>
}
});
var ConnectedBox = connect(map)(Box);
var Grid = React.createClass({
render: function() {
console.log('grid render')
return (
<div>
{this.props.grid.map((row, y) => {
return row.map((box, x) => {
return <ConnectedBox key={'x'+x+'y'+y} box={box} x={x} y={y} colours={this.props.colours} />;
})
})}
</div>
)
}
});
var ConnectedGrid = connect(map)(Grid);
ReactDOM.render(
<Provider store={store}>
<ConnectedGrid colours={colours} />
</Provider>,
document.getElementById('container')
);
我有一个大网格,我希望能够在鼠标悬停时“着色”,使用 redux 进行更改,但是即使只更改了一个框对象,react 每次都会重新渲染每个框变化,我不知道为什么?这让它变得超级慢
【问题讨论】:
标签: reactjs redux react-redux