詳解React中的todo-list
基于React的一個簡單Todo-list
先賭為快:在線DEMO,感覺還不錯點一下star -_- ~
源碼地址:
一、已經(jīng)完成的功能
1、新增選項(默認未完成)
2、完成狀態(tài)可以切換
3、當前選項可以刪除
4、全部選項選中狀態(tài)切換
5、全部個數(shù),完成個數(shù),未完成個數(shù)實時讀取
6、刷新狀態(tài)不變
7、雙擊可以編輯(有個坑:雙擊編輯內(nèi)input的keyUp Enter保存會連帶觸發(fā)blur失去焦點保存。已解決:通過設(shè)置一個可以保存的狀態(tài)控制)
二、待完成(新增路由)
三、目錄結(jié)構(gòu)
3.1、主要邏輯只涉及:Todo(父組件),TodoAdd(輸入框子組件一),TodoList(選項列表子組件二)
3.2、父子組件通過props(可以是自定義屬性、對象、回調(diào)函數(shù))通信,每個組件都有自己的state,可以通過setState改變當前的state。
例如:新增的時候,父組件是如何知道新增了一個什么內(nèi)容呢?如下:
// Todo.jsx內(nèi) //1 傳遞給子組件的回調(diào)函數(shù),只要有心得內(nèi)容傳遞過來,就更新當前的:list。list只要更新,通過props傳遞給TodoList的data就會更新,DOM就會新增一個選項列表 onAddSubmit(addTitle) { console.log("增加了:" + addTitle) let addItem = { title: addTitle, isFinished: false } this.state.list.unshift(addItem) this.setState({ list: this.state.list }) this._saveToSession() } // 通過props傳遞給子組件(等待使用) <TodoAdd onAddSubmit={this.onAddSubmit} /> // TodoAdd.jsx // 2、點擊enter鍵:有值就確認增加 _onKeyUpEnter(e) { if (e.keyCode == 13) { this.confirmAddItem() } } // 3、失去焦點:有值就確認增加 _onBlurEnter(e) { this.confirmAddItem() } // 4、確認增加,調(diào)用父組件的回調(diào)函數(shù),傳遞參數(shù) confirmAddItem() { if (this.state.title) { this.props.onAddSubmit(this.state.title) //把新增的內(nèi)容通過props傳進來的回調(diào)函數(shù)告訴父組件Todo,有新的內(nèi)容來了 // 置空當前 this.setState({ title: "" }) } }
其他:上面這個簡單的父子組件的通信過程和es6模塊化通信非常類似,只是react做了優(yōu)化,比如上面的使用es6來模擬如下,只是做了通信模擬:
// Todo.js 父模塊 import TodoAdd from "./TodoAdd" import TodoList from "./TodoList" class Todo { constructor() { this.list = [] this.TodoAdd = new TodoAdd({ // 父模塊給子模塊的回調(diào) resetList: (content) => { if (content) { this._updateList(content) } } }) this.TodoList = new TodoList({ list: this.list, }) } _updateList(content) { this.list.push(content) // 調(diào)用子模塊的方法更新內(nèi)部列表 this.TodoList && this.TodoList._getNewList(this.list) } } module.exports = Todo // TodoAdd.js 新增子模塊 class TodoAdd { constructor({ resetList, }) { this.resetList = resetList } _onSubmit(str) { if (str) { // 1、告訴父模塊新增了 this.resetList(str) } } } module.exports = TodoAdd // TodoList.js 列表子模塊 class TodoList { constructor({ list, }) { this.list = [] this._getNewList(list) } // 3、監(jiān)聽父模塊是否要更新 _getNewList(newList) { this.list = newList // 其他操作 } } module.exports = TodoList
以上所述是小編給大家介紹的React中的todo-list ,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!
相關(guān)文章
React生命周期方法之componentDidMount的使用
這篇文章主要介紹了React生命周期方法之componentDidMount的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06使用 React hooks 實現(xiàn)類所有生命周期
react 自 16.8 開始,引入了 Hooks 概念,使得函數(shù)組件中也可以擁有自己的狀態(tài),并且可以模擬對應(yīng)的生命周期,這篇文章主要介紹了使用 React hooks 怎么實現(xiàn)類里面的所有生命周期,需要的朋友可以參考下2023-02-02詳解開發(fā)react應(yīng)用最好用的腳手架 create-react-app
本篇文章主要介紹了詳解開發(fā)react應(yīng)用最好用的腳手架 create-react-app,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04