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

淺析React中的受控組件和非受控組件

 更新時間:2021年05月18日 10:53:49   作者:非著名奶茶愛好者  
具體來說這是一種react非受控組件,其狀態(tài)是在input的react內(nèi)部控制,不受調(diào)用者控制??梢允褂檬芸亟M件來實現(xiàn)。下面就說說這個React中的受控組件與非受控組件的相關(guān)知識,感興趣的朋友一起看看吧

非受控組件

表單數(shù)據(jù)由DOM本身處理。即不受setState()的控制,與傳統(tǒng)的HTML表單輸入相似,input輸入值即顯示最新值(使用 ref從DOM獲取表單值)

1.非受控組件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<!--準(zhǔn)備好一個容器-->
<div id="test"></div>

<!--引入react核心庫-->
<script src="../js/react.development.js"></script>
<!--引入react-dom,用于支持react操作dom-->
<script src="../js/react-dom.development.js"></script>
<!--引入babel,用于將jsx轉(zhuǎn)為js-->
<script src="../js/babel.min.js"></script>
<!--引入prop-types,用于對組件標(biāo)簽屬性進(jìn)行限制-->
<script src="../js/prop-types.js"></script>

<script type="text/babel">
    class Login extends React.Component {
        myRef1 = React.createRef();
        myRef2 = React.createRef();
        handleSubmit = (event) => {
            event.preventDefault() // 阻止表單提交
            const username = this.myRef1.current
            const password = this.myRef2.current
            alert(`您輸入的用戶名是:${username.value},您輸入的密碼是:${password.value}`)
        }
        render() {
            return (
                <form onSubmit={this.handleSubmit}>
                    用戶名:<input ref={this.myRef1} type="text"/> &nbsp;
                    密碼:<input ref={this.myRef2} type="text"/> &nbsp;
                    <button>登錄</button>
                </form>
            )
        }
    }
    ReactDOM.render(<Login/>,document.getElementById('test'))
</script>
</body>
</html>

受控組件

在HTML中,標(biāo)簽<input>、<textarea>、<select>的值的改變通常是根據(jù)用戶輸入進(jìn)行更新。在React中,可變狀態(tài)通常保存在組件的狀態(tài)屬性中,并且只能使用 setState() 更新,而呈現(xiàn)表單的React組件也控制著在后續(xù)用戶輸入時該表單中發(fā)生的情況,以這種由React控制的輸入表單元素而改變其值的方式,稱為:“受控組件”。

2.受控組件 (受到控制)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<!--準(zhǔn)備好一個容器-->
<div id="test"></div>

<!--引入react核心庫-->
<script src="../js/react.development.js"></script>
<!--引入react-dom,用于支持react操作dom-->
<script src="../js/react-dom.development.js"></script>
<!--引入babel,用于將jsx轉(zhuǎn)為js-->
<script src="../js/babel.min.js"></script>
<!--引入prop-types,用于對組件標(biāo)簽屬性進(jìn)行限制-->
<script src="../js/prop-types.js"></script>

<script type="text/babel">
    class Login extends React.Component {
        // 初始化狀態(tài)
        state = {
            username: '',
            password: ''
        }

        // 保存用戶名到狀態(tài)中
        saveUsername = (e) => {
            this.setState({username: e.target.value})
        }

        // 保存密碼到狀態(tài)中
        savePassword = (e) => {
            this.setState({password: e.target.value})
        }

        handleSubmit = (e) => {
            e.preventDefault() // 阻止表單提交
            const {username,password} = this.state
            alert(`您輸入的用戶名是:${username},您輸入的密碼是:${password}`)
        }
        render() {
            // onChange是一有變化就改變
            return (
                <form onSubmit={this.handleSubmit}>
                    用戶名:<input onChange={this.saveUsername} type="text"/> &nbsp;
                    密碼:<input onChange={this.savePassword} type="text"/> &nbsp;
                    <button>登錄</button>
                </form>
            )
        }
    }
    ReactDOM.render(<Login/>,document.getElementById('test'))
</script>
</body>
</html>

在這里插入圖片描述

注意

一般情況,受控組件用的多,因為在非受控組件中會多次使用ref,而官方文檔上有些“請勿過度使用ref”,使用次數(shù)多了會存在效率上的問題。

結(jié)論

受控和非受控元素都有其優(yōu)點,根據(jù)具體情況選擇。如果表單在UI反饋方面非常簡單,則對ref進(jìn)行控制是完全正確的,即使用非受控組件。

特征 非受控制 受控
一次性檢索(例如表單提交) yes yes
及時驗證 no yes
有條件的禁用提交按鈕 no yes
執(zhí)行輸入格式 no yes
一個數(shù)據(jù)的幾個輸入 no yes
動態(tài)輸入 no yes

以上就是淺析React中的受控組件和非受控組件的詳細(xì)內(nèi)容,更多關(guān)于react受控組件和非受控組件的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • useEffect?返回函數(shù)執(zhí)行過程源碼解析

    useEffect?返回函數(shù)執(zhí)行過程源碼解析

    這篇文章主要為大家介紹了useEffect?返回函數(shù)執(zhí)行過程源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • React新文檔切記不要濫用Ref

    React新文檔切記不要濫用Ref

    這篇文章主要為大家介紹了React新文檔濫用Ref出現(xiàn)的問題詳解,以及如何正確的使用Ref,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2022-07-07
  • React-Native之定時器Timer的實現(xiàn)代碼

    React-Native之定時器Timer的實現(xiàn)代碼

    本篇文章主要介紹了React-Native之定時器Timer的實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • 使用React.forwardRef傳遞泛型參數(shù)

    使用React.forwardRef傳遞泛型參數(shù)

    這篇文章主要介紹了使用React.forwardRef傳遞泛型參數(shù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • React之防止按鈕多次點擊事件?重復(fù)提交

    React之防止按鈕多次點擊事件?重復(fù)提交

    這篇文章主要介紹了React之防止按鈕多次點擊事件?重復(fù)提交問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 在?React?中使用?i18next的示例

    在?React?中使用?i18next的示例

    這篇文章主要介紹了在?React?中使用?i18next,本文結(jié)合實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • 詳解React 父組件和子組件的數(shù)據(jù)傳輸

    詳解React 父組件和子組件的數(shù)據(jù)傳輸

    這篇文章主要介紹了React 父組件和子組件的數(shù)據(jù)傳輸?shù)南嚓P(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用React,感興趣的朋友可以了解下
    2021-04-04
  • react-router-dom簡介(推薦)

    react-router-dom簡介(推薦)

    react-router包含三種類型的組件:路由組件、路由匹配組件?、導(dǎo)航組件,在你使用這些組件的時候,都必須先從react-router-dom引入,這篇文章主要介紹了react-router-dom簡介,需要的朋友可以參考下
    2022-12-12
  • React如何接收excel文件下載導(dǎo)出功能封裝

    React如何接收excel文件下載導(dǎo)出功能封裝

    這篇文章主要介紹了React如何接收excel文件下載導(dǎo)出功能封裝,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • React父子組件互相通信的實現(xiàn)示例

    React父子組件互相通信的實現(xiàn)示例

    React中是單向數(shù)據(jù)流,數(shù)據(jù)只能從父組件通過屬性的方式傳給其子組件,本文主要介紹了React父子組件互相通信的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2023-11-11

最新評論