亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

React+Antd+Redux實現待辦事件的方法

2024-05-06 16:49:05
字體:
來源:轉載
供稿:網友

之前也是寫過一篇關于Redux的文章,來簡單理解一下Redux,以及該如何使用。今天我就來分享一個也是入門級別的,React+Redux+antd來實現簡單的待辦事件。同時也講講自己對Redux的理解。先來看一張圖吧:

React,Antd,Redux,待辦事件

我們簡單的比喻來讓我們更加好的理解Redux,我們這樣比喻(圖書館借書):
1.React Component:借書人
2.Action Creators:你要說你要借書這句話,肯定要說話吧,就是一句話:我要借書
3.Store:圖書館管理員
4.Reducer:圖書館管理員肯定不可能記得所有書,那么Reducer就是作為一本小冊子,供圖書館管理員查

通俗理解:我要借書,我要先說話,告訴圖書館管理員我要借書,當圖書館管理員知道了之后,但是它不可能知道所有的書籍在哪里,所以需要一本小冊子去找,最后找到了之后,再送到你手上。
專業術語理解:(Component)要借書,我要先說話(Action ),告訴圖書館管理員(Store)我要借書,當圖書館管理員知道了之后,但是它不可能知道所有的書籍在哪里,所以需要一本小冊子(Reducer)去找,最后找到了之后,再送到你(Component)手上。

當你看圖覺得蒙的時候你再看看這個比喻是不是更好理解了?流程我們大概清楚了,我們就開始來看怎么寫這個待辦事項吧。
我們先來列一個提綱吧,屢清楚思路再寫代碼。
1.react component(todolist.js)
2.引入antd
3.寫store
4.寫reducer
5.寫action

大概就是上面的一些流程:

如何引入antd呢?

官方文檔:鏈接描述

文件目錄結構如下:

React,Antd,Redux,待辦事件

創建文件之前,首先創建圖書館管理員(store),他不知道書具體在哪里,所以再創建小冊子(redux),給到圖書館管理員(store):

//src/redux/index.jsimport {createStore} from 'redux';import reducer from './reducer'const store=createStore(reducer);export default store;
//src/redux/reducer.jsconst defaultState={  inputValue:'',  list:[1,2]}export default(state=defaultState,action)=>{  return state;}

*注釋:剛開始state,這里一定要給state賦一個初始值,才不會報錯

接下來你就可以,在todolist.js中用store.getState()獲取到store的值,我把他直接賦值給狀態:

React,Antd,Redux,待辦事件

我先實現一個由Component發送action,store收到action,在由reducer接受處理,最后返回一個新的狀態,Component接收顯示:

//src/redux/TodoList.jsimport React from 'react';import 'antd/dist/antd.css';import { Input,Button,List} from 'antd';import store from './index';export default class TodoList extends React.Component{  constructor(props){    super(props);    this.state=store.getState();  }  componentDidMount(){    console.log(this.state);  }  handleChg=(e)=>{    const action={      type:'change_input_value',      inputValue:e.target.value    }    store.dispatch(action);  }  render(){     console.log(this.state)      return(      <div style={{marginTop:"10px",marginLeft:"20px"}}>        <Input placeholder="請輸入" style={{width:"400px",marginRight:"10px"}} onChange={this.handleChg} value={this.state.inputValue}/>        </div>      </div>    );  }  }

思路:我們通過input框中監聽內容變化發送action,reucer去處理

//src/redux/reducer.jsconst defaultState={  inputValue:'',  list:[1,2]}export default(state=defaultState,action)=>{  if(action.type==='change_input_value'){    const newState=JSON.parse(JSON.stringify(state))    newState.inputValue=action.inputValue;    return newState;  }    return state;}

你可以打印出newState看一下,你就會發現inputValue就是你輸入的值了。

接下來的就可以舉一反三了。

完整代碼:

///src/redux/index.jsimport {createStore} from 'redux';import reducer from './reducer'const store=createStore(reducer);
///src/redux/reducers.jsexport default store;const defaultState={  inputValue:'',  list:[1,2]}export default(state=defaultState,action)=>{  if(action.type==='change_input_value'){    const newState=JSON.parse(JSON.stringify(state))    newState.inputValue=action.inputValue;    return newState;  }  if(action.type==='send_message'){    const newState=JSON.parse(JSON.stringify(state))    newState.list.push(newState.inputValue);    newState.inputValue='';    return newState;  }  if(action.type==='delete_message'){    const newState=Object.assign({},state);    newState.list.splice(action.index,1);    return newState;  }  return state;}
///src/redux/todoList.jsimport React from 'react';import 'antd/dist/antd.css';import { Input,Button,List} from 'antd';import store from './index';const data=[  1,2,3];export default class TodoList extends React.Component{  constructor(props){    super(props);    this.state=store.getState();    store.subscribe(this.F5)  }  componentDidMount(){    console.log(this.state);  }  handleChg=(e)=>{    const action={      type:'change_input_value',      inputValue:e.target.value    }    store.dispatch(action);  }  handleSend=()=>{    const action={      type:'send_message',    }    store.dispatch(action);  }  F5=()=>{    this.setState(store.getState());  }  handleItem=(index)=>{    const action={      type:'delete_message',      index:index    }    store.dispatch(action);  }  render(){     console.log(this.state)      return(      <div style={{marginTop:"10px",marginLeft:"20px"}}>        <Input placeholder="請輸入" style={{width:"400px",marginRight:"10px"}} onChange={this.handleChg} value={this.state.inputValue}/>        <Button type="primary" onClick={this.handleSend}>發送</Button>        <div style={{width:"400px",marginTop:"10px"}}>        <List           bordered           dataSource={this.state.list}           renderItem={(item,index) => (<List.Item onClick={this.handleItem.bind(this,index)}>{item}</List.Item>)}/>        </div>      </div>    );  }  }
//index.jsimport React from 'react';import ReactDOM from 'react-dom';import './index.css';import TodoList from './redux/TodoList';ReactDOM.render(<TodoList />, document.getElementById('root'));

這樣就實現了一個利用redux來實現簡單的待辦事項.

相信你如果寫完這個demo之后,肯定對Redux大致有了了解。如果自己在寫的過程中有什么疑惑,歡迎提出,我會給你解答。后期也會更新一些關于Redux的其他方面的知識。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色悠悠久久88| 亚洲男女自偷自拍图片另类| 日韩视频免费在线| 亚洲精品短视频| 欧美国产视频一区二区| 日韩av快播网址| 欧美日韩国产色| 国产视频久久久久| 亚洲欧洲在线视频| 大荫蒂欧美视频另类xxxx| 国产97在线|日韩| 色婷婷综合成人| 久久国产加勒比精品无码| 国产成人精品在线视频| 欧美黑人一级爽快片淫片高清| 欧美激情欧美激情| 国精产品一区一区三区有限在线| 在线视频欧美日韩精品| 国产极品jizzhd欧美| 亚洲**2019国产| 欧美性做爰毛片| 精品亚洲一区二区三区四区五区| 久久久久日韩精品久久久男男| 国产精品第一页在线| 久久亚洲国产精品成人av秋霞| 亚洲情综合五月天| 欧美激情在线狂野欧美精品| 成人午夜激情免费视频| 日韩av在线资源| 亚洲精品国精品久久99热一| 国产欧美日韩丝袜精品一区| 日韩欧亚中文在线| 青青a在线精品免费观看| 成人福利在线观看| 国产精品日韩在线播放| 成人久久18免费网站图片| 国产99久久久欧美黑人| 欧美最顶级丰满的aⅴ艳星| 欧美一区二区三区……| 26uuu亚洲伊人春色| 人妖精品videosex性欧美| 日韩免费观看av| 欧美老少配视频| 国产91在线高潮白浆在线观看| 国产在线久久久| 国产婷婷成人久久av免费高清| 国语自产精品视频在线看| 国产精品久久久久久久久久新婚| 大伊人狠狠躁夜夜躁av一区| 国产成人97精品免费看片| 日韩电影免费观看中文字幕| 亚洲另类图片色| 国产日韩精品在线| 国产精品嫩草影院久久久| 91国产美女视频| 97在线视频免费看| 亚洲欧美国产日韩中文字幕| 国产精品一区二区久久国产| 欧美wwwxxxx| 免费成人高清视频| 国产精品一区二区三| 日韩高清av一区二区三区| 国产精品美女午夜av| 91在线观看欧美日韩| 国产精品免费久久久久影院| 日韩av成人在线| 欧美性感美女h网站在线观看免费| 国产精品永久在线| 欧美成年人视频| 久久精品在线播放| 欧美日韩不卡合集视频| 国产综合福利在线| 日韩风俗一区 二区| 久久精品视频在线| 色噜噜狠狠狠综合曰曰曰| 久久国产精品久久国产精品| 亚洲国产精品va在线看黑人| 国内精品400部情侣激情| 不卡av电影在线观看| 久久久久久久香蕉网| 国产成人一区二| 久久视频在线直播| 欧美午夜女人视频在线| 这里只有视频精品| 国产精品成人一区二区| 日韩免费在线观看视频| 欧美日韩一区二区免费视频| 日韩中文在线中文网在线观看| 国产精品美乳一区二区免费| 久久99国产精品久久久久久久久| 国产视频综合在线| 亚洲综合中文字幕在线| 国产精品久久久久久久久免费| 亚洲韩国日本中文字幕| 精品丝袜一区二区三区| 日韩精品在线视频美女| 国产ts一区二区| 亚洲精品中文字幕女同| 国产成人一区二区三区| 色偷偷av亚洲男人的天堂| 亚洲男人天堂视频| 国产亚洲人成网站在线观看| 亚洲精品福利视频| 成人免费在线视频网站| 亚洲精品有码在线| 亚洲色图偷窥自拍| 亚洲情综合五月天| 九色精品免费永久在线| 欧美性猛交xxxx免费看漫画| 亚洲国产黄色片| 3344国产精品免费看| 这里只有精品在线观看| 国产精品久久久久久超碰| 九九久久久久久久久激情| 日韩精品中文字| 九九精品在线播放| 上原亚衣av一区二区三区| 高清欧美一区二区三区| 日韩专区在线播放| 亚洲黄色www网站| 欧美日韩亚洲91| 亚洲国语精品自产拍在线观看| 久久精品免费电影| 亚洲美女视频网站| 国产精品久久久久久久天堂| 国产精品日韩av| 欧美精品情趣视频| 久久久国产精彩视频美女艺术照福利| 国产精品极品美女在线观看免费| 成人免费视频网址| 国产精品白嫩初高中害羞小美女| 中文字幕综合在线| 亚洲第一视频网| 亚洲视频日韩精品| 在线丨暗呦小u女国产精品| 91在线观看免费观看| 97国产真实伦对白精彩视频8| 91丨九色丨国产在线| 国产成人一区二区三区电影| 国产精品一区=区| 庆余年2免费日韩剧观看大牛| 欧美日韩在线第一页| 欧美一级大胆视频| 一区二区三区高清国产| 这里只有精品在线播放| 欧美做受高潮电影o| 日韩av手机在线看| 7m精品福利视频导航| 欧美大片在线免费观看| 麻豆国产va免费精品高清在线| 永久免费毛片在线播放不卡| 亚洲黄色在线观看| 色综合老司机第九色激情| 欧美俄罗斯性视频| 久久久精品久久久| 国产精品久久久久久亚洲影视| 成人写真福利网| 欧美成人在线网站| 国产精品青青在线观看爽香蕉| 欧美日韩在线影院| 国产精品美女久久久久av超清| 亚洲人成网7777777国产| 久久精品电影网| 欧美大片免费观看|