标签:const render 实现 state 简单 action return redux store
<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title></title>
<script src="https://unpkg.com/react@16/umd/react.development.js"></script>
<script src="https://unpkg.com/react-dom@16/umd/react-dom.development.js"></script>
<script src="https://unpkg.com/babel-standalone@6.26.0/babel.js"></script>
</head>
<body>
<div id="root"></div>
<script type="text/babel">
function createStore(reducer) {
let state = {
num: 0
};
let listeners = []
const getState = () => state;
const dispatch = action => {
state = reducer(state, action)
listeners.forEach(listen => listen())
}
const subscribe = listener => {
listeners.push(listener);
return listeners.filter(item => item !== listener);
}
return { getState, dispatch, subscribe}
}
const store = createStore(reducer)
function reducer(state, action) {
if (action.type === 'add') {
return { ...state, num: state.num + action.payload }
}
return state;
}
class App extends React.Component {
add() {
store.dispatch({ type: 'add', payload: 5 })
console.log('state', store.getState())
}
render() {
return (
<div>
<div>Num: {store.getState().num}</div>
<button onClick={this.add}>+ 5</button>
</div>
)
}
}
const render = () => {
ReactDOM.render(<App />, document.getElementById('root'))
}
store.subscribe(render)
render()
</script>
</body>
</html>
标签:const,render,实现,state,简单,action,return,redux,store 来源: https://www.cnblogs.com/liea/p/13254258.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。