React-06React中refs屬性(字符串refs,回調形式,React.createRef() )

1.React中refs屬性

綁定到render輸出的任何組件上,通過this.ref.綁定名直接操作DOM元素或獲取子組件的實例。

2.綁定refs實例

2.1 字符串refs(已經過時參考官網API)

字符串(string)的ref存在一定的效率問題

  <input ref='input1' type="text" placeholeder='點擊按鈕提示數據'/>
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Hello,React</title>
</head><body><!-- 容器 --><div id="test"></div><!-- {/* // 引入 React核心庫 */} --><script src="https://unpkg.com/react@16/umd/react.production.min.js"></script><!-- {/* // 引入 react-dom 用于支持 react 操作 DOM */} --><script src="https://unpkg.com/react-dom@16/umd/react-dom.production.min.js"></script><!-- {/* // 引入 babel:1. ES6 ==> ES5 2. jsx ==> js */} --><script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script><!-- {/* // 引入 JSX 語法 */} --><script type="text/babel">// 1.創建組件class MyComponent extends React.Component {render() {return (<div><input ref='input1' type="text" placeholeder='點擊按鈕提示數據'/>&nbsp;<button ref='button1' onClick={this.showData}>點擊提示左側數據</button>&nbsp;<input ref='input2' onBlur={this.showData2} type="text" placeholeder='失去焦點提示數據'/></div>)}// 左側事件處理函數 ref標識使用showData = () => {console.log(this);alert(this.refs.input1.value);}// 右側事件處理函數 失去焦點觸發showData2 = () => {alert(this.refs.input2.value);}}// 2. 渲染虛擬DOM到頁面ReactDOM.render(<MyComponent />,document.getElementById('test'))</script>
</body></html>
2.2 回調形式refs
<input ref={c => this.input1 = c} type="text" placeholeder='點擊按鈕提示數據'/>

整體代碼

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Hello,React</title>
</head><body><!-- 容器 --><div id="test"></div><!-- {/* // 引入 React核心庫 */} --><script src="https://unpkg.com/react@16/umd/react.production.min.js"></script><!-- {/* // 引入 react-dom 用于支持 react 操作 DOM */} --><script src="https://unpkg.com/react-dom@16/umd/react-dom.production.min.js"></script><!-- {/* // 引入 babel:1. ES6 ==> ES5 2. jsx ==> js */} --><script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script><!-- {/* // 引入 JSX 語法 */} --><script type="text/babel">// 1.創建組件class MyComponent extends React.Component {// 回調函數 形式的ref標識使用render() {return (<div><input ref={c => this.input1 = c} type="text" placeholeder='點擊按鈕提示數據'/>&nbsp;<button onClick={this.showData}>點擊提示左側數據</button>&nbsp;<input ref={c => this.input2 = c} onBlur={this.showData2} type="text" placeholeder='失去焦點提示數據'/></div>)}// 左側事件處理函數 ref標識使用showData = () => {const {input1} =thisalert(input1.value);}// 右側事件處理函數 失去焦點觸發showData2 = () => {const {input2} =thisalert(input2.value);}}// 2. 渲染虛擬DOM到頁面ReactDOM.render(<MyComponent />,document.getElementById('test'))</script>
</body></html>
2.2.1?回調函數refs以內聯方式定義,更新過程中會執行兩次

????????ref回調函數如果以內聯函數的方式定義,在更新的過程中會執行兩次,第一次傳入null,第二次傳入參數DOM元素,每次渲染時會創建新的函數實例,所以React清空舊的的ref并設置新的。影響幾乎不存在

?整體代碼

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Hello,React</title>
</head><body><!-- 容器 --><div id="test"></div><!-- {/* // 引入 React核心庫 */} --><script src="https://unpkg.com/react@16/umd/react.production.min.js"></script><!-- {/* // 引入 react-dom 用于支持 react 操作 DOM */} --><script src="https://unpkg.com/react-dom@16/umd/react-dom.production.min.js"></script><!-- {/* // 引入 babel:1. ES6 ==> ES5 2. jsx ==> js */} --><script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script><!-- {/* // 引入 JSX 語法 */} --><script type="text/babel">// 1.創建組件class MyComponent extends React.Component {state = {isHot:true}// 事件處理函數 ref標識使用showData = () => {const {input1} =thisalert(input1.value);}// 回調函數 形式的ref標識使用render() {const {isHot} = this.statereturn (<div><h2>{isHot?'很熱':'很冷'}</h2><button onClick={()=>this.setState({isHot:!isHot})}>點擊切換天氣</button>&nbsp;<input ref={c => {this.input1 = c;console.log('渲染次數:',c)}} type="text" placeholeder='點擊按鈕提示數據'/>&nbsp;<button onClick={this.showData}>點擊提示左側數據</button>&nbsp;</div>)}}// 2. 渲染虛擬DOM到頁面ReactDOM.render(<MyComponent />,document.getElementById('test'))</script>
</body></html>
2.3 React.createRef()?容器存儲ref所標識的節點
2.3.1 聲明調用
 // 調用后返回容器(聲明唯一標識使用),容器存儲ref所標識的節點myRef = React.createRef()
 showData = () => {console.log(this.myRef.current.value);alert(this.myRef.current.value);}
2.3.2 對應節點綁定?
<input ref={this.myRef} type="text" placeholeder='點擊按鈕提示數據'/>&nbsp;  
2.3.3 整體代碼?
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Hello,React</title>
</head><body><!-- 容器 --><div id="test"></div><!-- {/* // 引入 React核心庫 */} --><script src="https://unpkg.com/react@16/umd/react.production.min.js"></script><!-- {/* // 引入 react-dom 用于支持 react 操作 DOM */} --><script src="https://unpkg.com/react-dom@16/umd/react-dom.production.min.js"></script><!-- {/* // 引入 babel:1. ES6 ==> ES5 2. jsx ==> js */} --><script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script><!-- {/* // 引入 JSX 語法 */} --><script type="text/babel">// 1.創建組件class MyComponent extends React.Component {// 調用后返回容器(聲明唯一標識使用),容器存儲ref所標識的節點myRef = React.createRef()myRef2 = React.createRef()// 事件處理函數showData = () => {console.log(this.myRef.current.value);alert(this.myRef.current.value);}// 失去焦點處理函數showData2 = () => {console.log(this.myRef.current.value);alert(this.myRef.current.value);}render() {return (<div><input ref={this.myRef} type="text" placeholeder='點擊按鈕提示數據'/>&nbsp;  <button onClick={this.showData}>點擊</button>&nbsp;   <input ref={this.myRef2} onBlur={this.showData2}  type="text" placeholeder='點擊按鈕提示數據'/>&nbsp;          </div>)}}// 2. 渲染虛擬DOM到頁面ReactDOM.render(<MyComponent />,document.getElementById('test'))</script>
</body></html>

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/76157.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/76157.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/76157.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

五子棋游戲開發:靜態資源的重要性與設計思路

以下是以CSDN博客的形式整理的關于五子棋游戲靜態資源需求的文章&#xff0c;基于我們之前的討論&#xff0c;內容結構清晰&#xff0c;適合開發者閱讀和參考。我盡量保持技術性、實用性&#xff0c;同時加入一些吸引讀者的亮點。 五子棋游戲開發&#xff1a;靜態資源的重要性與…

c編譯和c++編譯有什么區別?

文章目錄 c編譯和c編譯有什么區別多態函數重載虛函數表 vtable 輸入輸出同步類型檢查模板和特化鏈接 C 標準庫 C 能編譯 C 的代碼嗎&#xff1f; c編譯和c編譯有什么區別 多態 函數重載 C 支持多個同名函數&#xff08;參數不同&#xff09;&#xff0c;這是編譯期多態 編譯…

無縫集成Docker與Maven:docker-maven-plugin實戰指南

關于 docker-maven-plugin 的詳細介紹和使用指南&#xff0c;幫助你在 Maven 項目中實現 Docker 鏡像的自動化構建、推送和管理。 1. 插件的作用 docker-maven-plugin 是一個 Maven 插件&#xff0c;允許在 Maven 構建生命周期中直接集成 Docker 操作&#xff0c;例如&#xf…

智能倉儲數字孿生Demo(Unity實現)

一、項目背景與行業痛點 醫藥流通行業倉儲管理面臨三大核心挑戰&#xff1a; 合規性風險&#xff1a;GSP&#xff08;藥品經營質量管理規范&#xff09;對溫濕度、藥品批次追溯的嚴苛要求&#xff0c;傳統人工記錄易出錯效率瓶頸&#xff1a;庫區布局復雜&#xff0c;人工巡檢…

詳解 Go 的常見環境變量及其在 zshrc 中的配置

Go 語言作為一門現代化的編程語言&#xff0c;其編譯、構建和包管理等環節都依賴于一系列環境變量的配置。正確理解和設置這些環境變量&#xff0c;對于 Go 開發至關重要。本文將詳細介紹 Go 的常見環境變量&#xff0c;并解釋如何將其配置到 zshrc 文件中&#xff0c;以方便日…

【NLP 55、強化學習與NLP】

萬事開頭難&#xff0c;苦盡便是甜 —— 25.4.8 一、什么是強化學習 強化學習和有監督學習是機器學習中的兩種不同的學習范式 強化學習&#xff1a;目標是讓智能體通過與環境的交互&#xff0c;學習到一個最優策略以最大化長期累積獎勵。 不告訴具體路線&#xff0c;首先去做…

Java 面試系列:Java 中的運算符和流程控制 + 面試題

算術運算符 Java 中的算術運算符&#xff0c;包括以下幾種&#xff1a; 算術運算符名稱舉例加法123-減法2-11*乘法2*36/除法24/83%求余24%73自增1int i1;i--自減1int i1;i-- 我們本講要重點講的是 “” 和 “--”&#xff0c;其他的算術運算符相對比較簡單直觀&#xff0c;本講…

硅谷甄選項目筆記

硅谷甄選運營平臺 此次教學課程為硅谷甄選運營平臺項目,包含運營平臺項目模板從0到1開發&#xff0c;以及數據大屏幕、權限等業務。 此次教學課程涉及到技術棧包含***:vue3TypeScriptvue-routerpiniaelement-plusaxiosecharts***等技術棧。 一、vue3組件通信方式 通信倉庫地…

zk基礎—zk實現分布式功能

1.zk實現數據發布訂閱 (1)發布訂閱系統一般有推模式和拉模式 推模式&#xff1a;服務端主動將更新的數據發送給所有訂閱的客戶端。 拉模式&#xff1a;客戶端主動發起請求來獲取最新數據(定時輪詢拉取)。 (2)zk采用了推拉相結合來實現發布訂閱 首先客戶端需要向服務端注冊自己關…

大坑!GaussDB數據庫批量插入數據變只讀

大坑!GaussDB數據庫批量插入數據變只讀 GaussDB插入數據時變只讀df和du為什么不一致GaussDB磁盤空間使用閾值GaussDB變只讀怎么辦正確刪除表的姿勢GaussDB插入數據時變只讀 涉及的數據庫版本為:GaussDB Kernel 505.1.0 build da28c417。 GuassDB TPCC灌數報錯DML失敗,數據…

動態規劃算法深度解析:0-1背包問題(含完整流程)

簡介&#xff1a; 0-1背包問題是經典的組合優化問題&#xff1a;給定一組物品&#xff08;每個物品有重量和價值&#xff09;&#xff0c;在背包容量限制下選擇物品裝入背包&#xff0c;要求總價值最大化且每個物品不可重復選取。 動態規劃核心思想 通過構建二維狀態表dp[i]…

ABAP,PDF,ADS,FORM,PRINT

ABAP怎么直接打印PDF文件? https://faskomyabap.blogspot.com/2017/10/how-to-print-pdf-file-content-from-abap.html 里面的程序可以直接將本地文件打印出來,讀一下過程,這個程序是把本地PDF文件使用upload函數到ABAP中,先是二進制,然后轉成XSTRING,然后使用 連招 ADS…

C++Cherno 學習筆記day17 [66]-[70] 類型雙關、聯合體、虛析構函數、類型轉換、條件與操作斷點

b站Cherno的課[66]-[70] 一、C的類型雙關二、C的union&#xff08;聯合體、共用體&#xff09;三、C的虛析構函數四、C的類型轉換五、條件與操作斷點——VisualStudio小技巧 一、C的類型雙關 作用&#xff1a;在C中繞過類型系統 C是強類型語言 有一個類型系統&#xff0c;不…

011_異常、泛型和集合框架

異常、泛型和集合框架 異常Java的異常體系異常的作用 自定義異常異常的處理方案異常的兩種處理方式 泛型泛型類泛型接口泛型方法、通配符和上下限泛型支持的類型 集合框架集合體系結構Collection Collection集合Collection的遍歷方式認識并發修改異常問題解決并發修改異常問題的…

Kubernetes 集群搭建(三):使用dashboard用戶界面(需要訪問外網獲取yaml)

&#xff08;一&#xff09;簡介 K8s Dashboard是Kubernetes提供的一種基于Web的用戶界面工具&#xff0c;用于可視化地管理和監控Kubernetes集群 主要功能&#xff1a; 資源查看與管理&#xff1a; 查看Kubernetes集群中的各種資源&#xff0c;如節點、Pod、服務、部署等。 對…

【數據挖掘】嶺回歸(Ridge Regression)和線性回歸(Linear Regression)對比實驗

這是一個非常實用的 嶺回歸&#xff08;Ridge Regression&#xff09;和線性回歸&#xff08;Linear Regression&#xff09;對比實驗&#xff0c;使用了 scikit-learn 中的 California Housing 數據集 來預測房價。 &#x1f4e6; 第一步&#xff1a;導入必要的庫 import num…

大疆無人機系列知識

目錄 知識 開發者文檔 &#xff08;上云&#xff09; 無人機的應用 知識 大疆行業無人機接入音視頻平臺協議詳解_大疆無人機 視頻流-CSDN博客 開發者文檔 &#xff08;上云&#xff09; 上云API 無人機的應用 【大疆無人機地圖測繪技術學習&#xff1a;高精度、高效率的…

CNN注意力機制的進化史:深度解析10種注意力模塊如何重塑卷積神經網絡

&#x1f31f; 引言&#xff1a;注意力為何改變CNN的命運&#xff1f; 就像人類視覺會優先聚焦于重要信息&#xff0c;深度學習模型也需要"學會看重點"。從2018年SENet首提通道注意力&#xff0c;到2024年SSCA探索空間-通道協同效應&#xff0c;注意力機制正成為CNN…

Linux/樹莓派網絡配置、遠程登錄與圖形界面訪問實驗

一.準備工作 1.修改網絡適配器&#xff08;選擇本機網卡&#xff09; 2.創建一個新的用戶。 3.使用新用戶登錄&#xff0c;使用ip a指令查看IP&#xff08;現代 Linux 發行版&#xff08;如 Ubuntu、Debian、CentOS、Fedora 等&#xff09;&#xff09;。 通過sudo arp-sca…

Python----TensorFlow(TensorFlow介紹,安裝,主要模塊,高級功能)

一、TensorFlow TensorFlow 是由谷歌大腦團隊于 2015 年推出的開源機器學習框架。作為深度學習的第二代系統&#xff0c;TensorFlow 支持多種編程語言&#xff0c;包括 Python、C、Java 和 Go&#xff0c;廣泛應用于 CNN、RNN 和 GAN 等深度學習算法。 TensorFlow 可以…