欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react component changing uncontrolled input報(bào)錯(cuò)解決

 更新時(shí)間:2022年12月02日 17:13:01   作者:Borislav Hadzhiev  
這篇文章主要為大家介紹了react component changing uncontrolled input報(bào)錯(cuò)解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

總覽

當(dāng)input的值被初始化為undefined,但后來又變更為一個(gè)不同的值時(shí),會(huì)產(chǎn)生"A component is changing an uncontrolled input to be controlled"警告。為了解決該問題,將input的值初始化為空字符串。比如說,value={message || ''} 。

這里有個(gè)例子來展示錯(cuò)誤是如何發(fā)生的。

import {useState} from 'react';
const App = () => {
  // ??? didn't provide an initial value for message
  const [message, setMessage] = useState();
  const handleChange = event => {
    setMessage(event.target.value);
  };
  return (
    <div>
      <input
        type="text"
        id="message"
        name="message"
        onChange={handleChange}
        value={message}
      />
    </div>
  );
};
export default App;

上面代碼的問題在于,message變量被初始化為undefined,因?yàn)槲覀儧]有在useState鉤子中為其傳遞初始值。

備用值

解決該錯(cuò)誤的一種方式是,如果input的值為undefined,那么就提供一個(gè)備用值。

import {useState} from 'react';
const App = () => {
  const [message, setMessage] = useState();
  const handleChange = event => {
    setMessage(event.target.value);
  };
  // ???  value={message || ''}
  return (
    <div>
      <input
        type="text"
        id="message"
        name="message"
        onChange={handleChange}
        value={message || ''}
      />
    </div>
  );
};
export default App;

我們使用邏輯與(||)操作符,如果操作符左側(cè)的為假值(比如說undefined),則返回其右側(cè)的值。

如果message變量的值存儲(chǔ)為undefined,我們將空字符串作為備用值進(jìn)行返回。

useState

另一種解決方案是,在useState鉤子中為state變量傳遞初始值。

import {useState} from 'react';
const App = () => {
  // ??? pass an initial value to the useState hook
  const [message, setMessage] = useState('');
  const handleChange = event => {
    setMessage(event.target.value);
  };
  return (
    <div>
      <input
        type="text"
        id="message"
        name="message"
        onChange={handleChange}
        value={message}
      />
    </div>
  );
};
export default App;

useState鉤子中傳遞初始值可以避免警告,因?yàn)榇藭r(shí)message變量并沒有從undefined變更為一個(gè)值。

引起警告的原因是,當(dāng)message變量在沒有值的情況下被初始化時(shí),它會(huì)被設(shè)置為undefined。

傳遞一個(gè)像value={undefined}這樣的屬性,就等于根本沒有傳遞value屬性。

一旦用戶在input中開始輸入,value屬性就會(huì)被傳遞到input表單,輸入就會(huì)從不受控變?yōu)槭芸?,這是不被允許的。

defaultValue

注意,如果你使用一個(gè)不受控制的input表單,你應(yīng)該使用defaultValue屬性而不是value。

import {useRef} from 'react';
const App = () => {
  const inputRef = useRef(null);
  function handleClick() {
    console.log(inputRef.current.value);
  }
  return (
    <div>
      <input
        ref={inputRef}
        type="text"
        id="message"
        name="message"
        defaultValue="Initial value"
      />
      <button onClick={handleClick}>Log message</button>
    </div>
  );
};
export default App;

上述示例使用了不受控制的input。注意input表單上并沒有設(shè)置onChange或者value屬性。

你可以使用defaultValue屬性來為不受控制的input傳遞初始值。然而,這一步驟不是必要的,如果你不想設(shè)置初始值,你可以省略該屬性。

當(dāng)使用不受控制的input表單時(shí),我們使用ref來訪問input元素。每當(dāng)用戶點(diǎn)擊例子中的按鈕時(shí),不受控制的input 的值都會(huì)被記錄下來。

你不應(yīng)該為不受控制的input設(shè)置value屬性,因?yàn)檫@將使input表單不可變,你將無法在其中輸入。

原文鏈接:bobbyhadz.com/blog/react-…

以上就是react component changing uncontrolled input報(bào)錯(cuò)解決的詳細(xì)內(nèi)容,更多關(guān)于react component uncontrolled報(bào)錯(cuò)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • React中嵌套組件與被嵌套組件的通信過程

    React中嵌套組件與被嵌套組件的通信過程

    這篇文章主要介紹了React中嵌套組件與被嵌套組件的通信過程,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-07-07
  • React?redux?原理及使用詳解

    React?redux?原理及使用詳解

    這篇文章主要為大家介紹了React?redux?原理及使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • react系列從零開始_簡(jiǎn)單談?wù)剅eact

    react系列從零開始_簡(jiǎn)單談?wù)剅eact

    下面小編就為大家?guī)硪黄猺eact系列從零開始_簡(jiǎn)單談?wù)剅eact。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-07-07
  • React合成事件詳解

    React合成事件詳解

    這篇文章主要介紹了React合成事件的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用React,感興趣的朋友可以了解下
    2021-05-05
  • React-Native 組件之 Modal的使用詳解

    React-Native 組件之 Modal的使用詳解

    本篇文章主要介紹了React-Native 組件之 Modal的使用詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-08-08
  • React模擬實(shí)現(xiàn)Vue的keepAlive功能

    React模擬實(shí)現(xiàn)Vue的keepAlive功能

    Vue中,keep-alive組件可以緩存組件狀態(tài),在路由切換時(shí)重新掛載,實(shí)現(xiàn)這一功能在React中并不簡(jiǎn)單,但我們可以借助一個(gè)第三方庫——react-activation 來模擬Vue的keep-alive功能,需要的朋友可以參考下
    2024-10-10
  • 一文掌握React?組件樹遍歷技巧

    一文掌握React?組件樹遍歷技巧

    這篇文章主要為大家介紹了React?組件樹遍歷技巧的掌握,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • React虛擬列表的實(shí)現(xiàn)

    React虛擬列表的實(shí)現(xiàn)

    在開發(fā)過程中,總是遇到很多列表的顯示。當(dāng)上數(shù)量級(jí)別的列表渲染于瀏覽器,終會(huì)導(dǎo)致瀏覽器的性能下降,你可以選擇其他方式避免,本文就介紹了虛擬列表來解決這個(gè)問題
    2021-05-05
  • Electron+React進(jìn)行通信的方法

    Electron+React進(jìn)行通信的方法

    electron其實(shí)是一個(gè)桌面應(yīng)用程序,不是一個(gè)標(biāo)準(zhǔn)的前端web程序,所有沒有什么請(qǐng)求的發(fā)生,控制臺(tái)network看不到請(qǐng)求,而是只能通過console.log去打印查看,而且通信協(xié)議使用的不是http而是gRPC協(xié)議,這篇文章主要介紹了Electron+React如何進(jìn)行通信,需要的朋友可以參考下
    2022-06-06
  • React中useState原理的代碼簡(jiǎn)單實(shí)現(xiàn)

    React中useState原理的代碼簡(jiǎn)單實(shí)現(xiàn)

    要實(shí)現(xiàn)useState的背后原理,則需要深入了解狀態(tài)是如何在函數(shù)組件的渲染周期中保持和更新的,本文將通過一段代碼簡(jiǎn)單闡述useState鉤子函數(shù)的實(shí)現(xiàn)思路,希望對(duì)大家有所幫助
    2023-12-12

最新評(píng)論