成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

如何使用React Hooks建立一個待辦事項列表

waruqi / 1463人閱讀

摘要:構(gòu)建事項列表待辦事項清單是使用廣泛的例子,理由很充分它們是很棒的練習(xí)工具。對表單使用我們的表單應(yīng)該跟蹤的值并在保存提交時執(zhí)行方法。記得敲哦對事項列表使用我們的事項列表也需要。在中傳遞這個函數(shù)我們使用方法把所有不符合的事項保存下來。

原文地址:How to Build a Todo List with React Hooks

React v16.7.0-alpha 引入了鉤子(Hooks)。開心!

什么是鉤子(Hooks)?

鉤子是能讓你在沒有用es6類的情況下使用React的狀態(tài), 生命周期鉤子這些特性的功能。

優(yōu)勢:

隔離狀態(tài)相關(guān)邏輯,使測試更加容易

不需要使用渲染屬性或者高階組件就可以共享狀態(tài)相關(guān)邏輯

根據(jù)邏輯而不是生命周期鉤子來分離應(yīng)用程序的關(guān)注點

避免ES6類,因為它們很奇怪,不是真正的類,甚至?xí)`導(dǎo)有經(jīng)驗的JavaScript開發(fā)人員

查看更多:React’s official Hooks intro

不要在生產(chǎn)環(huán)境使用

寫這篇文章時,鉤子還處于內(nèi)部測試(alpha)階段。它們的API隨時都可能改變。
我建議你在你的業(yè)余項目中體驗鉤子,在它們成為穩(wěn)定版本之前,不要在線上代碼中使用。

構(gòu)建事項列表

待辦事項清單是使用廣泛的例子,理由很充分——它們是很棒的練習(xí)工具。無論你想嘗試任何語言或庫我都推薦使用它。
在這個例子中,我們只實現(xiàn)其中的一小部分功能:

使用Material Design展示事項列表

通過input添加事項

刪除事項

配置

這是github和CodeSandbox的地址

git clone https://github.com/yazeedb/react-hooks-todo
cd react-hooks-todo
npm install

master分支已經(jīng)實現(xiàn)了這些功能,如果你想自己跟著實現(xiàn),請切到start分支。

git checkout start

啟動工程

npm start

這個應(yīng)用應(yīng)該跑在localhost:3000上,這是初始UI:

我們已經(jīng)設(shè)置了material-ui來給頁面一個專業(yè)的外觀,現(xiàn)在我們加入更多功能!

ToDoForm 組件

添加一個新文件,src/TodoForm.js。這是初始代碼:

import React from "react";
import TextField from "@material-ui/core/TextField";
const TodoForm = ({ saveTodo }) => {
  return (
    
); }; export default TodoForm;

通過組件名字,我們就知道它是用來添加事項的,它也就是我們的第一個鉤子。

useState

看這段代碼:

import { useState } from "react";
const [value, setValue] = useState("");

useState是一個接收初始狀態(tài)(state)返回一個數(shù)組的函數(shù)。console.log 它吧。
數(shù)組的第一個值是你的state現(xiàn)在的值,第二個值是state的更新方法。

所以我們把它們叫做valuesetValue, 并使用es6解構(gòu)賦值對它們進(jìn)行賦值。

對表單(Form)使用useState

我們的表單應(yīng)該跟蹤input的值并在保存提交時執(zhí)行saveTodo方法。useState能幫我們實現(xiàn)它。

更新updateForm.js, 這是更新之后的代碼:

import React, { useState } from "react";
import TextField from "@material-ui/core/TextField";
const TodoForm = ({ saveTodo }) => {
  const [value, setValue] = useState("");
  return (
    
onSubmit={event => { event.preventDefault(); saveTodo(value); }} > { setValue(event.target.value); }} value={value} /> ); }; export default TodoForm;

回到index.js,引入并且使用這個組件。

...
import TodoForm from "./TodoForm";
...
const App = () => {
  return (
    
Todos
); };

現(xiàn)在你在input輸入的值已經(jīng)可以被打印出來了。(記得敲enter哦)

對事項列表(todos)使用useState

我們的事項列表todos也需要state。在index.js中引入useState。初始state應(yīng)該是空數(shù)組。

import React, { useState } from "react";
...
const App = () => {
  const [todos, setTodos] = useState([]);
  return ...
TodoList組件

建立一個新文件:src/TodoList.js

大部分代碼是來自Material-UI庫的高級組件, 這是更新之后的代碼:

import React from "react";
import List from "@material-ui/core/List";
import ListItem from "@material-ui/core/ListItem";
import ListItemSecondaryAction from "@material-ui/core/ListItemSecondaryAction";
import ListItemText from "@material-ui/core/ListItemText";
import Checkbox from "@material-ui/core/Checkbox";
import IconButton from "@material-ui/core/IconButton";
import DeleteIcon from "@material-ui/icons/Delete";

const TodoList = ({ todos, deleteTodo }) => (
  
    {todos.map((todo, index) => (
      
        
        
        
           {
              deleteTodo(index);
            }}
          >
            
          
        
      
    ))}
  
);

export default TodoList;

它接收兩個屬性:

todos: 事項數(shù)組,我們遍歷數(shù)組,建立每一個事項

deleteTodo: 點擊一個事項的刪除按鈕觸發(fā)這個方法,它接收一個參數(shù): 索引,這個索引唯一標(biāo)識每一個事項。

index.js中引入這個組件。

...
import TodoList from "./TodoList";
import "./styles.css";
const App = () => { ...

并在App方法中使用它:

...

添加事項

還是在index.js中,編輯TodoForm的屬性, saveTodo

 {
    const trimmedText = todoText.trim();
    if (trimmedText.length > 0) {
      setTodos([...todos, trimmedText]);
    }
  }}
/>

這里我們只是把空格去掉,把新的值添加到todos中。

我們現(xiàn)在可以添加事項了!

清除input框

現(xiàn)在添加新的事項后,我們沒有把input清空,這是不好的用戶體驗!
我們只需要在TodoForm.js中做一點小改動,就可以修復(fù)它。

{ event.preventDefault(); saveTodo(value); setValue(""); }} >

當(dāng)事項被保存后,我們就把form的state變成空字符串。
現(xiàn)在看起來很好了!

刪除事項

TodoList為每一條事項都提供了索引,根據(jù)索引我們能找到我們想刪除的事項。

// TodoList.js
 {
    deleteTodo(index);
  }}
>
  

index.js中傳遞這個函數(shù)

 {
    const newTodos = todos
      .filter((_, index) => index !== todoIndex);
  
    setTodos(newTodos);
  }}
/>

我們使用setTodos方法把所有不符合index的事項保存下來。
刪除功能完成!

抽取事項列表(todos)的useState

文章開頭我提到 鉤子便于分離狀態(tài)和組件的邏輯。所以我們在這個應(yīng)用中可以這樣做。

新建一個文件叫src/useTodoState.js

import { useState } from "react";

export default initialValue => {
  const [todos, setTodos] = useState(initialValue);

  return {
    todos,
    addTodo: todoText => {
      setTodos([...todos, todoText]);
    },
    deleteTodo: todoIndex => {
      const newTodos = todos
        .filter((_, index) => index !== todoIndex);

      setTodos(newTodos);
    }
  };
};

這就是index.js中原來的代碼,我們只是把它分離出來了!我們的狀態(tài)處理邏輯不再和組件混在一起了!

現(xiàn)在我們只需要引入它,這是更新之后的代碼:

import React from "react";
import ReactDOM from "react-dom";
import Typography from "@material-ui/core/Typography";
import TodoForm from "./TodoForm";
import TodoList from "./TodoList";
import useTodoState from "./useTodoState";
import "./styles.css";

const App = () => {
  const { todos, addTodo, deleteTodo } = useTodoState([]);

  return (
    
Todos { const trimmedText = todoText.trim(); if (trimmedText.length > 0) { addTodo(trimmedText); } }} />
); }; const rootElement = document.getElementById("root"); ReactDOM.render(, rootElement);

現(xiàn)在一切工作正常!

抽取表單input中的useState

我們可以對表單做同樣的處理!
新建一個文件:src/useInputState.js

import { useState } from "react";

export default initialValue => {
  const [value, setValue] = useState(initialValue);

  return {
    value,
    onChange: event => {
      setValue(event.target.value);
    },
    reset: () => setValue("")
  };
};

現(xiàn)在todoForm.js應(yīng)該變成這樣:

import React from "react";
import TextField from "@material-ui/core/TextField";
import useInputState from "./useInputState";

const TodoForm = ({ saveTodo }) => {
  const { value, reset, onChange } = useInputState("");

  return (
     {
        event.preventDefault();

        saveTodo(value);
        reset();
      }}
    >
      
    
  );
};

export default TodoForm;

現(xiàn)在我們?nèi)客瓿闪耍?br>希望你喜歡?。?br>謝謝!
作者:Yazeed Bzadough

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/99978.html

相關(guān)文章

  • 利用Dawn工程化工具實踐MobX數(shù)據(jù)流管理方案

    摘要:新的項目目錄設(shè)計如下放置靜態(tài)文件業(yè)務(wù)組件入口文件數(shù)據(jù)模型定義數(shù)據(jù)定義工具函數(shù)其中數(shù)據(jù)流實踐的核心概念就是數(shù)據(jù)模型和數(shù)據(jù)儲存。最后再吃我一發(fā)安利是阿里云業(yè)務(wù)運營事業(yè)部前端團(tuán)隊開源的前端構(gòu)建和工程化工具。 本文首發(fā)于阿里云前端dawn團(tuán)隊專欄。 項目在最初應(yīng)用 MobX 時,對較為復(fù)雜的多人協(xié)作項目的數(shù)據(jù)流管理方案沒有一個優(yōu)雅的解決方案,通過對MobX官方文檔中針對大型可維護(hù)項目最佳實踐的...

    0x584a 評論0 收藏0
  • 用好React,你必須要知道的事情

    摘要:屬性如何獲取,是容器性組件負(fù)責(zé)的事情。所以,不要依賴和的值計算下一個狀態(tài)。也可以使用帶用回調(diào)函數(shù)參數(shù)版本的,回調(diào)函數(shù)中的會保證是最新的。當(dāng)返回時,組件本次的方法不會被觸發(fā)。 容器性組件(container component)和展示性組件(presentational component) 使用React編寫組件時,我們需要有意識地將組件劃分為容器性組件(container compo...

    vvpvvp 評論0 收藏0
  • angular - 收藏集 - 掘金

    摘要:如何在中使用動畫前端掘金本文講一下中動畫應(yīng)用的部分。與的快速入門指南推薦前端掘金是非常棒的框架,能夠創(chuàng)建功能強大,動態(tài)功能的。自發(fā)布以來,已經(jīng)廣泛應(yīng)用于開發(fā)中。 如何在 Angular 中使用動畫 - 前端 - 掘金本文講一下Angular中動畫應(yīng)用的部分。 首先,Angular本生不提供動畫機制,需要在項目中加入Angular插件模塊ngAnimate才能完成Angular的動畫機制...

    AlexTuan 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<