做爰高潮a片〈毛片〉,尤物av天堂一区二区在线观看,一本久久A久久精品VR综合,添女人荫蒂全部过程av

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

React組件中的this的具體使用

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:18:24
文檔

React組件中的this的具體使用

React組件中的this的具體使用:React組件的this是什么 通過編寫一個(gè)簡(jiǎn)單組件,并渲染出來,分別打印出自定義函數(shù)和render中的this: import React from 'react'; const STR = '被調(diào)用,this指向:'; class App extends React.Component{ constructo
推薦度:
導(dǎo)讀React組件中的this的具體使用:React組件的this是什么 通過編寫一個(gè)簡(jiǎn)單組件,并渲染出來,分別打印出自定義函數(shù)和render中的this: import React from 'react'; const STR = '被調(diào)用,this指向:'; class App extends React.Component{ constructo
 //測(cè)試函數(shù)
 handler() {
 console.log(`handler ${STR}`,this);
 }

 render(){
 console.log(`render ${STR}`,this);

 this.handler();
 window.handler = this.handler;
 window.handler();

 return(

 <div>
 <h1>hello World</h1>
 <label htmlFor = 'btn'>單擊打印函數(shù)handler中this的指向</label>
 <input id = "btn" type="button" value = '單擊' onClick = {this.handler}/>
 </div> 
 )
 }
}
export default App

可以看到:

  1. render中this -> 組件實(shí)例App對(duì)象;
  2. render中this.handler() -> 組件實(shí)例App對(duì)象 ;
  3. render中window.handler() -> window對(duì)象;
  4. onClick ={this.handler} -> undefined

繼續(xù)使用事件觸發(fā)組件的裝載、更新和卸載過程:

/index.js
import React from 'react'
import {render,unmountComponentAtNode} from 'react-dom'

import App from './App.jsx'


const root=document.getElementById('root')

console.log("首次掛載");
let instance = render(<App />,root);

window.renderComponent = () => {
 console.log("掛載");
 instance = render(<App />,root);
}

window.setState = () => {
 console.log("更新");
 instance.setState({foo: 'bar'});
}


window.unmountComponentAtNode = () => {
 console.log('卸載');
 unmountComponentAtNode(root);
}

使用三個(gè)按鈕觸發(fā)組件的裝載、更新和卸載過程:

/index.html
<!DOCTYPE html>
<html>
<head>
 <title>react-this</title>
</head>
<body>
 <button onclick="window.renderComponent()">掛載</button>
 <button onclick="window.setState()">更新</button>
 <button onclick="window.unmountComponentAtNode()">卸載</button>
 <div id="root">
 <!-- app -->
 </div>
</body>
</html>

運(yùn)行程序,依次單擊“掛載”,綁定onClick={this.handler}“單擊”按鈕,“更新”和“卸載”按鈕結(jié)果如下:

1. render()以及componentDIdMount()、componentDIdUpdate()等其他生命周期函數(shù)中的this都是組件實(shí)例;

2. this.handler()的調(diào)用者,為render()中的this,所以打印組件實(shí)例;

3. window.handler()的“調(diào)用者”,為window,所以打印window;

4. onClick={this.handler}的“調(diào)用者”為事件綁定,來源多樣,這里打印undefined。

-面對(duì)如此混亂的場(chǎng)景,如果我們想在onClick中調(diào)用自定義的組件方法,并在該方法中獲取組將實(shí)例,我們就得進(jìn)行轉(zhuǎn)換上下文即綁定上下文:

自動(dòng)綁定和手動(dòng)綁定

  1. React.createClass有一個(gè)內(nèi)置的魔法,可以自動(dòng)綁定所用的方法,使得其this指向組件的實(shí)例化對(duì)象,但是其他JavaScript類并沒有這種特性;
  2. 所以React團(tuán)隊(duì)決定不再React組件類中實(shí)現(xiàn)自動(dòng)綁定,把上下文轉(zhuǎn)換的自由權(quán)交給開發(fā)者;
  3. 所以我們通常在構(gòu)造函數(shù)中綁定方法的this指向:
import React from 'react';
const STR = '被調(diào)用,this指向:';
class App extends React.Component{
 constructor(){
 super();
 this.handler = this.handler.bind(this);
 }
//測(cè)試函數(shù)
 handler() {
 console.log(`handler ${STR}`,this);
 }

 render(){
 console.log(`render ${STR}`,this);
 this.handler();
 window.handler = this.handler;
 window.handler();

 return(
 <div>
 <h1>hello World</h1>
 <label htmlFor = 'btn'>單擊打印函數(shù)handler中this的指向</label>
 <input id = "btn" type="button" value = '單擊' onClick = {this.handler}/>
 </div> 
 )
 }
}
export default App

將this.handler()綁定為組件實(shí)例后,this.handler()中的this就指向組將實(shí)例,即onClick={this.handler}打印出來的為組件實(shí)例;

總結(jié):

React組件生命周期函數(shù)中的this指向組件實(shí)例;

自定義組件方法的this會(huì)因調(diào)用者不同而不同;

為了在組件的自定義方法中獲取組件實(shí)例,需要手動(dòng)綁定this到組將實(shí)例。

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

React組件中的this的具體使用

React組件中的this的具體使用:React組件的this是什么 通過編寫一個(gè)簡(jiǎn)單組件,并渲染出來,分別打印出自定義函數(shù)和render中的this: import React from 'react'; const STR = '被調(diào)用,this指向:'; class App extends React.Component{ constructo
推薦度:
標(biāo)簽: 中使用 組件 this
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 工布江达县| 云龙县| 九龙县| 祁连县| 潢川县| 中卫市| 宜宾市| 九龙坡区| 神池县| 巴林左旗| 平武县| 柳河县| 浏阳市| 扎鲁特旗| 无棣县| 丰镇市| 滕州市| 青铜峡市| 岳普湖县| 涞源县| 浠水县| 岳池县| 古丈县| 铜川市| 衡山县| 兴业县| 万盛区| 湘潭县| 黄骅市| 岫岩| 湟源县| 郴州市| 肥城市| 根河市| 清原| 广元市| 翼城县| 旬阳县| 工布江达县| 仙游县| 柘城县|