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

React?createRef循環(huán)動(dòng)態(tài)賦值ref問(wèn)題

 更新時(shí)間:2023年01月16日 14:11:01   作者:acezhwang  
這篇文章主要介紹了React?createRef循環(huán)動(dòng)態(tài)賦值ref問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

React createRef循環(huán)動(dòng)態(tài)賦值ref

react的refs已經(jīng)是過(guò)時(shí)的API了,不適合用于循環(huán)動(dòng)態(tài)賦值ref,最近又在項(xiàng)目中遇到需要循環(huán)動(dòng)態(tài)賦值ref,這是用createRef的方法,在此記錄一下,親測(cè)有效!

handleChange = (key) => {
    this[`input${key}Ref`] = React.createRef();
}
 
handleSave = () => {
    const { list } = this.state;
    for (let item of list) {
        if (item.value && item.value.length > 100) {
          Toast.show(`${item.name}不能超過(guò)100個(gè)字符`);
          this[`input${item.key}Ref`].current&&this[`input${item.key}Ref`].current.focus();
          return;
        }
    }
    // 寫接口等其他邏輯
 }
 
render() {
    const { list } = this.state;
    <div>
        {
            list.map(item=>{
              <Input
                  ref={this[`input${item.key}Ref`]}
                  value={item.value}
                  onChange={() => { this.handleChange(item.key) }}
              />
            })
        }
        <Button type="primary" onClick={this.handleSave}>保存</Button>
     </div>
}

React中ref的理解

(1) React的ref有3種用法

字符串

dom節(jié)點(diǎn)上使用,通過(guò)this.refs[refName]來(lái)引用真實(shí)的dom節(jié)點(diǎn)

<input ref="inputRef" /> //this.refs['inputRef']來(lái)訪問(wèn)

回調(diào)函數(shù)

React 支持給任意組件添加特殊屬性。ref 屬性接受一個(gè)回調(diào)函數(shù),它在組件被加載或卸載時(shí)會(huì)立即執(zhí)行。

  • 當(dāng)給 HTML 元素添加 ref 屬性時(shí),ref 回調(diào)接收了底層的 DOM 元素作為參數(shù)。
  • 當(dāng)給組件添加 ref 屬性時(shí),ref 回調(diào)接收當(dāng)前組件實(shí)例作為參數(shù)。
  • 當(dāng)組件卸載的時(shí)候,會(huì)傳入null

ref 回調(diào)會(huì)在componentDidMount 或 componentDidUpdate 這些生命周期回調(diào)之前執(zhí)行。

<input ref={(input) => {this.textInput = input;}} type="text" /> ? //HTML 元素添加 ref 屬性時(shí)
<CustomInput ref={(input) => {this.textInput = input;}} /> ? //組件添加 ref 屬性

React.createRef()

在React 16.3版本后,使用此方法來(lái)創(chuàng)建ref。將其賦值給一個(gè)變量,通過(guò)ref掛載在dom節(jié)點(diǎn)或組件上,該ref的current屬性

將能拿到dom節(jié)點(diǎn)或組件的實(shí)例

class Child extends React.Component{
? ? constructor(props){
? ? ? ? super(props);
? ? ? ? this.myRef=React.createRef();
? ? }
? ? componentDidMount(){
? ? ? ? console.log(this.myRef.current);
? ? }
? ? render(){
? ? ? ? return <input ref={this.myRef}/>
? ? }
}

(2) 根據(jù)ref獲取dom

React提供的這個(gè)ref屬性,表示為對(duì)組件真正實(shí)例的引用,其實(shí)就是ReactDOM.render()返回的組件實(shí)例,但可以通過(guò)ReactDOM.findDOMNode(ref)來(lái)獲取組件掛載后真正的dom節(jié)點(diǎn)

var Parent = React.createClass({
? render: function(){
? ? return (
? ? ? <div className = 'parent'>
? ? ? ? <Child ref = 'child'/>
? ? ? </div>
? ? )
? },
? componentDidMount(){
? ? console.log(this.refs.child); // 訪問(wèn)掛載在組件上ref
? ? console.log(ReactDOM.findDOMNode(this.refs.child)); // 訪問(wèn)真正的dom節(jié)點(diǎn)
? }
})

var Child = React.createClass({
? render: function() {
? ? return (
? ? ? ? <div ref="test">
? ? ? ? ? <a ref="update">更新</a>
? ? ? ? </div>
? ? );
? }
});

(3) react-redux使用時(shí)利用ref調(diào)用子組件方法不可用報(bào)錯(cuò)

在使用react的時(shí)候,我們難免會(huì)在父組件中調(diào)用子組件的方法,我們常用ref調(diào)用子組件的方法

如下在父組件中調(diào)用子組件的寫法

父組件

handleShowModalAdd = () => {
? ? this.add.handleToggle()//handleToggle為子組件中的方法
}
<SystemAdd ref={(el) => this.add = el}/>

但是當(dāng)我們?cè)谧咏M件中使用redux的時(shí)候,由于使用connect對(duì)子組件進(jìn)行了包裝,會(huì)導(dǎo)致獲取不到子組件中的方法

下面的是使用redux后的ref使用方法

父組件

handleShowModalAdd = () => {
? ? this.add.handleToggle()//handleToggle為子組件中的方法
}
<SystemAdd onRef={(ref) => this.add = ref }/>

子組件

componentDidMount(){
? ? this.props.onRef(this)//將組件實(shí)例this傳遞給onRef方法
}

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • React使用highlight.js Clipboard.js實(shí)現(xiàn)代碼高亮復(fù)制

    React使用highlight.js Clipboard.js實(shí)現(xiàn)代碼高亮復(fù)制

    這篇文章主要為大家介紹了React使用highlight.js Clipboard.js實(shí)現(xiàn)代碼高亮復(fù)制功能示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • Jira 任務(wù)管理系統(tǒng)項(xiàng)目總結(jié)講解

    Jira 任務(wù)管理系統(tǒng)項(xiàng)目總結(jié)講解

    這篇文章主要為大家介紹了Jira 任務(wù)管理系統(tǒng)項(xiàng)目總結(jié)講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • react.js 獲取真實(shí)的DOM節(jié)點(diǎn)實(shí)例(必看)

    react.js 獲取真實(shí)的DOM節(jié)點(diǎn)實(shí)例(必看)

    下面小編就為大家?guī)?lái)一篇react.js 獲取真實(shí)的DOM節(jié)點(diǎn)實(shí)例(必看)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-04-04
  • React的diff算法核心復(fù)用圖文詳解

    React的diff算法核心復(fù)用圖文詳解

    這篇文章主要為大家介紹了React的diff算法核心復(fù)用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • React中映射一個(gè)嵌套數(shù)組實(shí)現(xiàn)demo

    React中映射一個(gè)嵌套數(shù)組實(shí)現(xiàn)demo

    這篇文章主要為大家介紹了React中映射一個(gè)嵌套數(shù)組實(shí)現(xiàn)demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • React Router6.x路由表封裝的兩種寫法

    React Router6.x路由表封裝的兩種寫法

    本文主要介紹了React Router6.x路由表封裝的兩種寫法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • react-redux中connect()方法詳細(xì)解析

    react-redux中connect()方法詳細(xì)解析

    connect()是React-redux中的核心方法之一,它將react組件預(yù)redux中的Store真正連接在一起,下面這篇文章主要給大家介紹了react-redux中connect()方法的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-05-05
  • React組件傳參方式你了解嗎

    React組件傳參方式你了解嗎

    眾所周知?,在業(yè)務(wù)開發(fā)中,無(wú)論用的什么框架,首先要熟悉項(xiàng)目搭建,路由配置和組件通信,所以我們今天要探究的就是React中組件通信的幾種方式,快跟隨小編一起學(xué)習(xí)起來(lái)吧
    2024-03-03
  • 重新理解?React?useRef原理

    重新理解?React?useRef原理

    這篇文章主要為大家介紹了React?useRef原理的深入理解分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • React Native 混合開發(fā)多入口加載方式詳解

    React Native 混合開發(fā)多入口加載方式詳解

    這篇文章主要介紹了React Native 混合開發(fā)多入口加載方式詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09

最新評(píng)論