1建立context对象 const {Provider, Consumer} = React.createContext()
2 Provider包这最大的组件 并经过value属性传递数据(注:必须是value属性)
3 哪一个组件要使用数据,就经过 Consumer包起来
<!DOCTYPE html> <html lang="en"> <head> <title>Document</title> <meta charset="UTF-8"> </head> <body> <div id="app"> </div> <script src="https://cdn.staticfile.org/react/16.4.0/umd/react.development.js"></script> <script src="https://cdn.staticfile.org/react-dom/16.4.0/umd/react-dom.development.js"></script> <script src="https://cdn.staticfile.org/babel-standalone/6.26.0/babel.min.js"></script> <script type="text/babel"> // 建立一个 Context 对象 const {Provider, Consumer} = React.createContext() //1.定义 class Father extends React.Component { render() { return <Provider value={{data1:111, data2:222}}> <fieldset> <legend>Father</legend> <Middle/> </fieldset> </Provider> } } class Middle extends React.Component { render() { return <fieldset> <legend>Middle</legend> <Son /> </fieldset> } } class Son extends React.Component { render() { return <Consumer> {value => <fieldset> <legend>Son</legend> <p>{value.data1}</p> <p>{value.data2}</p> </fieldset>} </Consumer> } } //2.渲染 ReactDOM.render(<Father />, document.querySelector("#app")) </script> </body> </html>
调用组件:<组件名>包含 html 标签的内容 </组件名>
获取组件内容:this.props.children (另外写法 <组件名 children=数据></组件名>)
<!DOCTYPE html> <html lang="en"> <head> <title>Document</title> <meta charset="UTF-8"> </head> <body> <div id="app"> </div> <script src="https://cdn.staticfile.org/react/16.4.0/umd/react.development.js"></script> <script src="https://cdn.staticfile.org/react-dom/16.4.0/umd/react-dom.development.js"></script> <script src="https://cdn.staticfile.org/babel-standalone/6.26.0/babel.min.js"></script> <script type="text/babel"> // 1. 定义组件 class Modal extends React.Component { render() { return ( <fieldset> <legend>自定义遮罩框</legend> {this.props.msg} {/* 获取组件中的内容 props.children */} {this.props.children} </fieldset> ) } } // 2. 渲染组件 ReactDOM.render(<div> <Modal msg="<p style='color:green'>删除成功</p>"> <h1 style={{color:'green'}}>删除成功</h1> <p>南京</p> </Modal> <Modal msg="肯定删除吗?"> <p>北京</p> </Modal> </div>, document.querySelector('#app')) </script> </body> </html>
建立仓库:const store = Redux.createStore( reducer)
取数据:store.getState()
更新:store.dispatch({type:动做}) 参数专业数据action
通知:store.subscribe(回调函数)
function(state = 数据, action) { switch(action.type) { case 'AAAA': //逻辑处理 return .... case 'NNNN': //逻辑处理 return default: //逻辑处理 return } }
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <h1>周瑜打黄盖距今:<span></span></h1> <button class="add">递增</button> <button class="del">递减</button> <script src="https://unpkg.com/redux@latest/dist/redux.min.js "></script> <script> let initState = { num: 666 } let reducers = (state = initState, action) => { switch (action.type) { case 'ADD': state.num += 1 break; case 'DEL': state.num -= 1 break; default: break; } // console.log(state) return state } // 1. 建立仓库<-reducers搞数据 const store = Redux.createStore(reducers) console.log(store) console.log(store.getState()) // 2. 获取数 页面展现 document.querySelector('span').innerHTML = store.getState().num // 3. 更新数据 document.querySelector('.add').onclick = function() { store.dispatch({type:'ADD'}) // dispatch将实参交给reducers的第二个形参action // 强烈推荐type大写,后期模块名_动做来命名 } document.querySelector('.del').onclick = function() { store.dispatch({type:'DEL'}) } // 4. 监听数据库变化 留心本身监听 react-redux store.subscribe(()=>{ //从新获取数据 document.querySelector('span').innerHTML = store.getState().num }) </script> </body> </html>