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

React獲取input值并提交的2種方法實例

 更新時間:2021年04月14日 10:55:24   作者:GuanJdoJ  
這篇文章主要給大家介紹了關(guān)于React獲取input值并提交的2種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

方法一  利用DOM提供的Event對象的target事件屬性取值并提交

import React from 'react';
 
class InputDemo extends React.Component{
  state = {
    InputValue : "",//輸入框輸入值
  };
 
  handleGetInputValue = (event) => {
    this.setState({
      InputValue : event.target.value,
    })
  };
 
  handlePost = () => {
    const {InputValue} = this.state;
    console.log(InputValue,'------InputValue');
    //在此做提交操作,比如發(fā)dispatch等
  };
 
  render(){
    return(
      <div>
        <input
          value={this.state.InputValue}
          onChange={this.handleGetInputValue}
        />
        <button onClick={this.handlePost}>提交</button>
      </div>
    )
  }
}
 
export default InputDemo;

這里的<input />和<button />都是用的html的標(biāo)簽,當(dāng)然也可以使用Antd的<Input />和<Button />組件,里面的內(nèi)容是不變的

首先在組件最上方state中定義了InputValue:"",下面<input />里寫了value={this.state.InputValue},如果去掉onChange事件,那么這時候輸入框里是什么都輸入不了的,因為

React認(rèn)為所有的狀態(tài)都應(yīng)該由 React 的 state 控制,只要類似于<input />、<textarea />、<select />這樣的輸入控件被設(shè)置了value值,那么它們的值永遠(yuǎn)以被設(shè)置的值為準(zhǔn)。如果值沒被改變,value就不會變化

React中要用setState才能更新組件的內(nèi)容,所以需要監(jiān)聽輸入框的onChange事件,獲取到輸入框的內(nèi)容后通過setState的方式更新state的InputValue,這樣<input />的內(nèi)容才會實時更新

再說onChange的handleGetInputValue方法,利用了DOM的Event對象的target事件屬性:

target 事件屬性可返回事件的目標(biāo)節(jié)點(觸發(fā)該事件的節(jié)點),如生成事件的元素、文檔或窗口

詳情可見W3C標(biāo)準(zhǔn)介紹

方法二  利用React的ref訪問DOM元素取值并提交

無狀態(tài)組件寫法:

const InputDemo = () => {
  let inputValue;
  const handlePost = (e) => {
    if (e) e.preventDefault();
    const valueTemp = inputValue.value;
    console.log(valueTemp, '------valueTemp');
    //在此做提交操作,比如發(fā)dispatch等
  };
 
  return (
    <div>
      <form onSubmit={handlePost}>
        <input
          ref={input => inputValue = input}
        />
        <button onClick={handlePost}>提交</button>
      </form>
    </div>
  )
};
 
export default InputDemo;

有狀態(tài)組件寫法:

import React from 'react';
 
class InputDemo extends React.Component {
  handlePost = (e) => {
    if (e) e.preventDefault();
    const valueTemp = this.inputValue.value;
    console.log(valueTemp, '------valueTemp');
    //在此做提交操作,比如發(fā)dispatch等
  };
 
  render() {
    return (
      <div>
        <form onSubmit={this.handlePost}>
          <input
            ref={input => this.inputValue = input}
          />
          <button onClick={this.handlePost}>提交</button>
        </form>
      </div>
    )
  }
};
 
export default InputDemo;

Ref 是 React 提供給我們的安全訪問 DOM 元素或者某個組件實例的句柄。我們可以為元素添加 ref 屬性,然后在回調(diào)函數(shù)中接受該元素在 DOM 樹中的句柄,該值會作為回調(diào)函數(shù)的第一個參數(shù)返回。

除了這兩種寫法,還可以利用Antd的Form組件實現(xiàn)表單功能,傳送門:React利用Antd的Form組件實現(xiàn)表單功能

總結(jié)

到此這篇關(guān)于React獲取input值并提交的2種方法的文章就介紹到這了,更多相關(guān)React獲取input值并提交內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React Native 如何獲取不同屏幕的像素密度

    React Native 如何獲取不同屏幕的像素密度

    這篇文章主要介紹了 React Native 如何 獲取不同屏幕的像素密度的相關(guān)資料,需要的朋友可以參考下
    2017-01-01
  • react-redux的connect用法詳解

    react-redux的connect用法詳解

    react-redux是react官方推出的redux綁定庫,React-Redux 將所有組件分成兩大類一個是UI組件和容器組件,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-01-01
  • React團隊測試并發(fā)特性詳解

    React團隊測試并發(fā)特性詳解

    這篇文章主要為大家介紹了React團隊測試并發(fā)特性詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • React?Native中原生實現(xiàn)動態(tài)導(dǎo)入的示例詳解

    React?Native中原生實現(xiàn)動態(tài)導(dǎo)入的示例詳解

    在React?Native社區(qū)中,原生動態(tài)導(dǎo)入一直是期待已久的功能,在這篇文章中,我們將比較靜態(tài)和動態(tài)導(dǎo)入,學(xué)習(xí)如何原生地處理動態(tài)導(dǎo)入,以及有效實施的最佳實踐,希望對大家有所幫助
    2024-02-02
  • react使用antd-design中select不能及時刷新問題及解決

    react使用antd-design中select不能及時刷新問題及解決

    這篇文章主要介紹了react使用antd-design中select不能及時刷新問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • React?Hooks--useEffect代替常用生命周期函數(shù)方式

    React?Hooks--useEffect代替常用生命周期函數(shù)方式

    這篇文章主要介紹了React?Hooks--useEffect代替常用生命周期函數(shù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • React組件間通信的三種方法(簡單易用)

    React組件間通信的三種方法(簡單易用)

    React知識中一個主要內(nèi)容便是組件之間的通信,以下列舉幾種常用的組件通信方式,本文就詳細(xì)的介紹一下,感興趣的可以了解一下
    2021-10-10
  • React?跨端動態(tài)化核心技術(shù)實例分析

    React?跨端動態(tài)化核心技術(shù)實例分析

    這篇文章主要為大家介紹了React?跨端動態(tài)化核心技術(shù)實例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • React Router V6更新內(nèi)容詳解

    React Router V6更新內(nèi)容詳解

    這篇文章主要為大家介紹了React Router V6更新內(nèi)容,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • Suspense對React的意義及作用解析

    Suspense對React的意義及作用解析

    這篇文章主要為大家介紹了Suspense對React的意義及作用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06

最新評論