雷火电竞-中国电竞赛事及体育赛事平台

歡迎來到入門教程網(wǎng)!

網(wǎng)頁編輯器

當(dāng)前位置:主頁 > 網(wǎng)絡(luò)編程 > 網(wǎng)頁編輯器 >

詳解React中的todo-list

來源:本站原創(chuàng)|時間:2020-01-11|欄目:網(wǎng)頁編輯器|點(diǎn)擊:

基于React的一個簡單Todo-list

先賭為快:在線DEMO,感覺還不錯點(diǎn)一下star  -_- ~

源碼地址:

一、已經(jīng)完成的功能

1、新增選項(默認(rèn)未完成)

2、完成狀態(tài)可以切換

3、當(dāng)前選項可以刪除

4、全部選項選中狀態(tài)切換

5、全部個數(shù),完成個數(shù),未完成個數(shù)實時讀取

6、刷新狀態(tài)不變

7、雙擊可以編輯(有個坑:雙擊編輯內(nèi)input的keyUp Enter保存會連帶觸發(fā)blur失去焦點(diǎn)保存。已解決:通過設(shè)置一個可以保存的狀態(tài)控制)

二、待完成(新增路由)

三、目錄結(jié)構(gòu)

3.1、主要邏輯只涉及:Todo(父組件),TodoAdd(輸入框子組件一),TodoList(選項列表子組件二)

3.2、父子組件通過props(可以是自定義屬性、對象、回調(diào)函數(shù))通信,每個組件都有自己的state,可以通過setState改變當(dāng)前的state。

例如:新增的時候,父組件是如何知道新增了一個什么內(nèi)容呢?如下:

// Todo.jsx內(nèi)   
//1 傳遞給子組件的回調(diào)函數(shù),只要有心得內(nèi)容傳遞過來,就更新當(dāng)前的: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、點(diǎn)擊enter鍵:有值就確認(rèn)增加
  _onKeyUpEnter(e) {
    if (e.keyCode == 13) {
      this.confirmAddItem()
    }
  }
  // 3、失去焦點(diǎn):有值就確認(rèn)增加
  _onBlurEnter(e) {
    this.confirmAddItem()
  }
  // 4、確認(rèn)增加,調(diào)用父組件的回調(diào)函數(shù),傳遞參數(shù)
  confirmAddItem() {
    if (this.state.title) {
      this.props.onAddSubmit(this.state.title) //把新增的內(nèi)容通過props傳進(jìn)來的回調(diào)函數(shù)告訴父組件Todo,有新的內(nèi)容來了
      // 置空當(dāng)前
      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 ,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!

上一篇:沒有了

欄    目:網(wǎng)頁編輯器

下一篇:沒有了

本文標(biāo)題:詳解React中的todo-list

本文地址:http://www.jygsgssxh.com/a1/wangyebianjiqi/11764.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有