react系列--redux
index
react系列--redux __veblen
redux本身与react没有任何关系,只是一个状态管理机制,接下来会从基础使用开始展示,希望可以大家可以有所收获!redux应用场景
- 某个组件的状态,需要共享
- 某个状态需要在任何地方都可以拿到
- 一个组件需要改变全局状态
- 一个组件需要改变另一个组件的状态
- index.html
Document - 锐客网
- index.js
function render(){ var arr=[1,2,3,4]; var str=""; for(var i=0; i"+arr[i]+"
"
}
list.innerHTMl=str;
}
render();
- index.js就变成了这个样子
function render(){ var arr=[1,2,3,4]; var str=""; for(var i=0; i"+arr[i]+"
"
}
list.innerHTML=str;
}
render();
var store=Redux.createStore(function(state,action){
switch (action.type){
case "add":
state.push(action.query)
return state ;
default : return [1,2,3,4,5]
}
})
通过redux.createStore(),创建store,以一个函数作为参数,该函数第一个参数是store管理的状态,通过store.getState()方法获取,第二个参数为监听dispatch
传递过来的内容
- 【react系列--redux】index.js
function render(){ var arr=store.getState(); var str=""; for(var i=0; i"+arr[i]+"
"
}
list.innerHTML=str;
}
var store=Redux.createStore(function(state,action){
switch (action.type){
case "add":
state.push(action.query)
return state ;
default : return [1,2,3,4,5]
}
})
render();
store.subscribe(render)
Store 允许使用store.subscribe方法设置监听函数,一旦 State 发生变化,就自动执行这个函数。
- index.js
function render(){ var arr=store.getState(); var str=""; for(var i=0; i"+arr[i]+"
"
}
list.innerHTML=str;
}
var store=Redux.createStore(function(state,action){
switch (action.type){
case "add":
state.push(action.query)
return state ;
default : return [1,2,3,4,5]
}
})
render();
store.subscribe(render);
add.onclick=function(){
var val=ipt.value;
store.dispatch({
type:"add",
query:val
})
}
点击btn
的时候,通过store.dispatch(action)
通知store
干活,state
改变之后,通过store.subscribe(render)
重新执行render函数,达到视图更新目的。如果其他视图以来state
状态,则只需将页面渲染放入render函数
Document - 锐客网
更深层次的封装
Document - 锐客网
在初始化的dispatch
时,action
的值为@@redux/INIT
推荐阅读
- 【欢喜是你·三宅系列①】⑶
- 你不可不知的真相系列之科学
- 人脸识别|【人脸识别系列】| 实现自动化妆
- react|react 安装
- 2018-06-13金句系列7(金句结构-改编古现代诗词)
- Unity和Android通信系列文章2——扩展UnityPlayerActivity
- 乡野村趣系列之烧仙草
- Java内存泄漏分析系列之二(jstack生成的Thread|Java内存泄漏分析系列之二:jstack生成的Thread Dump日志结构解析)
- 15、IDEA学习系列之其他设置(生成javadoc、缓存和索引的清理等)
- 【年终激励系列】之五(年终奖如何与考核紧密相连)