亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

React錯(cuò)誤的習(xí)慣用法分析詳解

 更新時(shí)間:2023年01月09日 08:54:52   作者:糖瓶  
這篇文章主要為大家介紹了React錯(cuò)誤用法習(xí)慣分析詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

過(guò)多的聲明state

在我們React的日常開(kāi)發(fā)中一些常用的寫(xiě)法,看似運(yùn)行的很好,實(shí)際可能并不優(yōu)雅。學(xué)習(xí)React并不是如何如何使用它,而是如何寫(xiě)出優(yōu)雅,干凈的代碼。下面舉一些例子,總結(jié)了一些React開(kāi)發(fā)中不好的寫(xiě)法及相應(yīng)更好的寫(xiě)法。(僅代表個(gè)人觀點(diǎn))

問(wèn)題

一個(gè)組件中聲明了過(guò)多的state,過(guò)多的setState方法。例如下面的這樣:

import { useState } from "react";
export default function MoreState() {
  const [username, setUsername] = useState("");
  const [age, setAge] = useState("");
  const [gender, setGender] = useState("");
  const [email, setEmail] = useState("");
  const [password, setPassword] = useState("");
  const [address, setAddress] = useState("");
  const [city, setCity] = useState("");
  const onSubmit = () => {
    // ...
  };
  return (
    <form onSubmit={onSubmit}>
      <input
        type="text"
        name="username"
        placeholder="username"
        value={username}
        onChange={(e) => setUsername(e.target.value)}
      />
      <br />
      <input
        type="text"
        name="age"
        placeholder="age"
        value={age}
        onChange={(e) => setAge(e.target.value)}
      />
      <br />
      <input
        type="text"
        name="gender"
        placeholder="gender"
        value={gender}
        onChange={(e) => setGender(e.target.value)}
      />
      <br />
      <input
        type="text"
        name="email"
        placeholder="email"
        value={email}
        onChange={(e) => setEmail(e.target.value)}
      />
      <br />
      <input
        type="text"
        name="password"
        placeholder="password"
        value={password}
        onChange={(e) => setPassword(e.target.value)}
      />
      <br />
      <input
        type="text"
        name="address"
        placeholder="address"
        value={address}
        onChange={(e) => setAddress(e.target.value)}
      />
      <br />
      <input
        type="text"
        name="city"
        placeholder="city"
        value={city}
        onChange={(e) => setCity(e.target.value)}
      />
      <br />
      <button type="submit">提交</button>
    </form>
  );
}

實(shí)際上這樣并不好維護(hù),接手項(xiàng)目的人都瘋了??。還有這樣的:

解決方法

把能合并的state,合并成一個(gè)對(duì)象表示。當(dāng)然也可以使用useReducer。當(dāng)屬性中出現(xiàn)嵌套結(jié)構(gòu)時(shí),例如屬性中有對(duì)象和數(shù)組時(shí),使用useReducer更好一些。

import { useState } from "react";
export default function MoreState() {
  const [userInfo, setUserInfo] = useState({
    username: "",
    age: "",
    gender: "",
    email: "",
    password: "",
    address: "",
    city: ""
  });
  const onChange = (e) => {
    setUserInfo((pre) => ({ ...pre, [e.target.name]: e.target.value }));
  };
  const onSubmit = (e) => {
    e.preventDefault();
    console.log(111, userInfo);
  };
  return (
    <form onSubmit={onSubmit}>
      <input
        type="text"
        name="username"
        placeholder="username"
        onChange={onChange}
      />
      <br />
      <input type="text" name="age" placeholder="age" onChange={onChange} />
      <br />
      <input
        type="text"
        name="gender"
        placeholder="gender"
        onChange={onChange}
      />
      <br />
      <input type="text" name="email" placeholder="email" onChange={onChange} />
      <br />
      <input
        type="text"
        name="password"
        placeholder="password"
        onChange={onChange}
      />
      <br />
      <input
        type="text"
        name="address"
        placeholder="address"
        onChange={onChange}
      />
      <br />
      <input type="text" name="city" placeholder="city" onChange={onChange} />
      <br />
      <button type="submit">提交</button>
    </form>
  );
}

不必要的state

問(wèn)題

我們?cè)陂_(kāi)發(fā)React表單時(shí),通常會(huì)使用state來(lái)記錄表單的值,例如:

import { useState } from "react";
export default function NoState() {
  const [username, setUsername] = useState("");
  const [password, setPassword] = useState("");
  const onSubmit = (e) => {
    e.preventDefault();
    console.log("需要提交的數(shù)據(jù)", username, password);
  };
  console.log("組件重新渲染了");
  return (
    <form onSubmit={onSubmit}>
      <label htmlFor="name">名字</label>
      <input
        type="text"
        value={username}
        onChange={(e) => setUsername(e.target.value)}
      />
      <br />
      <label htmlFor="name">密碼</label>
      <input
        type="text"
        value={password}
        onChange={(e) => setPassword(e.target.value)}
      />
      <br />
      <button type="submit">提交</button>
    </form>
  );
}

上面的代碼看似并沒(méi)有什么問(wèn)題,但是我們只是在提交的時(shí)候用到了state,并沒(méi)有在其他地方使用過(guò)這些state。這個(gè)例子中我們并不關(guān)心這些state值的變化,我們只關(guān)心我們提交的數(shù)據(jù)是否正確。而且我們每次輸入的時(shí)候組件都是重新渲染。這并不友好,這個(gè)時(shí)候我們需要非受控組件。

解決方法

當(dāng)表單元素不多時(shí),使用ref來(lái)處理,并且每次輸入都不會(huì)引起組件的重新渲染,因?yàn)檫@個(gè)時(shí)候我們只關(guān)心提交的數(shù)據(jù),沒(méi)有在其他地方使用過(guò)這些state。

import { useRef } from "react";
export default function NoState() {
  const usernameRef = useRef();
  const posswordRef = useRef();
  const onSubmit = (e) => {
    e.preventDefault();
    console.log(
      "需要提交的數(shù)據(jù)",
      usernameRef.current.value,
      posswordRef.current.value
    );
  };
  console.log("組件重新渲染了");
  return (
    <form onSubmit={onSubmit}>
      <label htmlFor="name">名字</label>
      <input type="text" ref={usernameRef} />
      <br />
      <label htmlFor="name">密碼</label>
      <input type="text" ref={posswordRef} />
      <br />
      <button type="submit">提交</button>
    </form>
  );
}

過(guò)多的useEffect

問(wèn)題

有時(shí)當(dāng)頁(yè)面第一次掛載時(shí),我們需要進(jìn)行網(wǎng)絡(luò)請(qǐng)求,我們經(jīng)常會(huì)這樣寫(xiě):

import { useEffect, useState } from "react";
export default function MoreUseEffect() {
  const [data, setData] = useState();
  useEffect(() => {
    fetch("/ss/ss").then((res) => {
      setData(res.data);
    });
  }, []);
  useEffect(() => {
    // 進(jìn)行其他邏輯處理...
    console.log(data);
  }, [data]);
  return <>頁(yè)面第一次加載時(shí)請(qǐng)求</>;
}

引入了過(guò)多的useEfffect,實(shí)際上我們只是需要使用請(qǐng)求到的數(shù)據(jù)來(lái)進(jìn)行其他邏輯的處理,并不需要數(shù)據(jù)變化時(shí)做一些事情。

解決方法

把數(shù)據(jù)的處理邏輯放入第一個(gè)useEffect中直接處理。

import { useEffect } from "react";
export default function MoreUseEffect() {
  useEffect(() => {
    fetch("/ss/ss").then((res) => {
    	// setData(res.data);
      // 在這里直接進(jìn)行數(shù)據(jù)處理...
      console.log('')
    });
  }, []);
  return <>頁(yè)面第一次加載時(shí)請(qǐng)求</>;
}

請(qǐng)求競(jìng)爭(zhēng)問(wèn)題

問(wèn)題

下面是對(duì)fetch請(qǐng)求進(jìn)行了封裝,這種寫(xiě)法有一個(gè)問(wèn)題:當(dāng)同時(shí)有多個(gè)請(qǐng)求時(shí),由于請(qǐng)求返回的時(shí)間不一樣,會(huì)出現(xiàn)競(jìng)爭(zhēng)關(guān)系,不會(huì)按照請(qǐng)求的順序返回結(jié)果,這樣就造成返回的結(jié)果不知道是哪次的。

import { useEffect, useState } from "react";
export default function useFetch(url) {
  const [loading, setLoading] = useState(true);
  const [data, setData] = useState();
  const [error, setError] = useState();
  useEffect(() => {
    setLoading(true);
    fetch(url)
      .then((res) => {
        setData(res.data);
      })
      .catch((e) => {
        setError(e);
      })
      .finally(() => setLoading(false));
  }, [url]);
  return {
    loading,
    data,
    error
  };
}

解決方法

需要在請(qǐng)求URL變化之后取消前一次的請(qǐng)求。

import { useEffect, useState } from "react";
export default function useFetch(url) {
  const [loading, setLoading] = useState(true);
  const [data, setData] = useState();
  const [error, setError] = useState();
  useEffect(() => {
    const controller = new AbortController();
    setLoading(true);
    fetch(url, { signal: controller.signal })
      .then((res) => {
        setData(res.data);
      })
      .catch((e) => {
        setError(e);
      })
      .finally(() => setLoading(false));
    return () => {
      controller.abort();
    };
  }, [url]);
  return {
    loading,
    data,
    error
  };
}

使用三元表達(dá)式代替&&

使用 && 常見(jiàn)的錯(cuò)誤

1.當(dāng)狀態(tài)值不是Boolean,而是數(shù)字0時(shí),數(shù)字0會(huì)在UI中顯示。

import { useState } from "react";
export default function MoreUseEffect() {
	const [arr] = useState([])
  return <>
    {
      arr.length && <div>11111</div>
    }
    </>;
}

解決方法

  • 轉(zhuǎn)成Boolean
  • 使用三元表達(dá)式代替 && (推薦)

傳遞特殊屬性ref

問(wèn)題

ref屬性是React的特殊屬性,不能直接傳遞使用。

import {useRef} from 'react'
function InputCom({ref}) {
  return (
    <input type='text' ref={ref} />
  )
}
function App() {
  const inpRef = useRef(null)
  const focus = () => {
    inpRef.current?.focus()
  }
  return (
    <>
      <InputCom ref={inpRef} />
    </>
  )
}

如果想傳遞ref需要借助forwardRef函數(shù)。

解決方法

借助forwardRef轉(zhuǎn)發(fā)ref屬性

import { forwardRef, useRef } from "react";
// function InputCom({ ref }) {
//   return <input type="text" ref={ref} />;
// }
const InputCom = forwardRef((props, ref) => {
  return <input type="text" ref={ref} />;
});
export default function ProRef() {
  const inpRef = useRef(null);
  const focus = () => {
    inpRef.current?.focus();
  };
  return (
    <>
      <InputCom ref={inpRef} />
      <br />
      <button onClick={focus}>focus</button>
    </>
  );
}

以上就是React錯(cuò)誤用法習(xí)慣分析詳解的詳細(xì)內(nèi)容,更多關(guān)于React錯(cuò)誤用法習(xí)慣的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • React應(yīng)用框架Dva數(shù)據(jù)流向原理總結(jié)分析

    React應(yīng)用框架Dva數(shù)據(jù)流向原理總結(jié)分析

    這篇文章主要為大家介紹了React 應(yīng)用框架Dva數(shù)據(jù)流向原理總結(jié)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • React?Streaming?SSR原理示例深入解析

    React?Streaming?SSR原理示例深入解析

    這篇文章主要為大家介紹了React?Streaming?SSR原理示例深入解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • 簡(jiǎn)化Cocos和Native交互利器詳解

    簡(jiǎn)化Cocos和Native交互利器詳解

    這篇文章主要為大家介紹了簡(jiǎn)化Cocos和Native交互利器詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • React Redux使用配置詳解

    React Redux使用配置詳解

    react-redux是redux官方react綁定庫(kù),能夠使react組件從redux store中讀取數(shù)據(jù),并且向store分發(fā)actions以此來(lái)更新數(shù)據(jù),這篇文章主要介紹了react-redux的設(shè)置,需要的朋友可以參考下
    2022-08-08
  • 漸進(jìn)式源碼解析React更新流程驅(qū)動(dòng)

    漸進(jìn)式源碼解析React更新流程驅(qū)動(dòng)

    這篇文章主要為大家介紹了漸進(jìn)式源碼解析React更新流程驅(qū)動(dòng)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • React中使用Mobx的方法

    React中使用Mobx的方法

    Mobx是一個(gè)前端“狀態(tài)管理框架”,狀態(tài)管理就是將分布在各個(gè)組件、各個(gè)模塊中的狀態(tài)的變化,按照一定的規(guī)則,進(jìn)行統(tǒng)一的管理,這篇文章主要介紹了React中如何使用Mobx,需要的朋友可以參考下
    2023-02-02
  • react解析html字符串方法實(shí)現(xiàn)

    react解析html字符串方法實(shí)現(xiàn)

    在使用reactjs庫(kù)的時(shí)候,會(huì)遇到將一段html的字符串,然后要將它插入頁(yè)面中以html的形式展現(xiàn),本文主要介紹了react解析html字符串方法實(shí)現(xiàn),感興趣的可以了解一下
    2023-12-12
  • react component changing uncontrolled input報(bào)錯(cuò)解決

    react component changing uncontrolled in

    這篇文章主要為大家介紹了react component changing uncontrolled input報(bào)錯(cuò)解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • react拖拽react-beautiful-dnd一維數(shù)組二維數(shù)組拖拽功能

    react拖拽react-beautiful-dnd一維數(shù)組二維數(shù)組拖拽功能

    二維數(shù)組可以拖拽,但是不可以編輯+拖拽,如果想要實(shí)現(xiàn)編輯+拖拽,還是需要轉(zhuǎn)換成一維數(shù)組,本文給大家介紹react拖拽react-beautiful-dnd的相關(guān)知識(shí),感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • react裝飾器與高階組件及簡(jiǎn)單樣式修改的操作詳解

    react裝飾器與高階組件及簡(jiǎn)單樣式修改的操作詳解

    這篇文章主要介紹了react裝飾器與高階組件及簡(jiǎn)單樣式修改的操作,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧
    2022-09-09

最新評(píng)論