• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    React組件中的this的具體使用

    來源:懂視網 責編:小采 時間:2020-11-27 22:18:24
    文檔

    React組件中的this的具體使用

    React組件中的this的具體使用:React組件的this是什么 通過編寫一個簡單組件,并渲染出來,分別打印出自定義函數和render中的this: import React from 'react'; const STR = '被調用,this指向:'; class App extends React.Component{ constructo
    推薦度:
    導讀React組件中的this的具體使用:React組件的this是什么 通過編寫一個簡單組件,并渲染出來,分別打印出自定義函數和render中的this: import React from 'react'; const STR = '被調用,this指向:'; class App extends React.Component{ constructo
     //測試函數
     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'>單擊打印函數handler中this的指向</label>
     <input id = "btn" type="button" value = '單擊' onClick = {this.handler}/>
     </div> 
     )
     }
    }
    export default App

    可以看到:

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

    繼續使用事件觸發組件的裝載、更新和卸載過程:

    /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);
    }

    使用三個按鈕觸發組件的裝載、更新和卸載過程:

    /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>

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

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

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

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

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

    -面對如此混亂的場景,如果我們想在onClick中調用自定義的組件方法,并在該方法中獲取組將實例,我們就得進行轉換上下文即綁定上下文:

    自動綁定和手動綁定

    1. React.createClass有一個內置的魔法,可以自動綁定所用的方法,使得其this指向組件的實例化對象,但是其他JavaScript類并沒有這種特性;
    2. 所以React團隊決定不再React組件類中實現自動綁定,把上下文轉換的自由權交給開發者;
    3. 所以我們通常在構造函數中綁定方法的this指向:
    import React from 'react';
    const STR = '被調用,this指向:';
    class App extends React.Component{
     constructor(){
     super();
     this.handler = this.handler.bind(this);
     }
    //測試函數
     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'>單擊打印函數handler中this的指向</label>
     <input id = "btn" type="button" value = '單擊' onClick = {this.handler}/>
     </div> 
     )
     }
    }
    export default App

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

    總結:

    React組件生命周期函數中的this指向組件實例;

    自定義組件方法的this會因調用者不同而不同;

    為了在組件的自定義方法中獲取組件實例,需要手動綁定this到組將實例。

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    React組件中的this的具體使用

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

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 大桥未久在线精品视频在线| 99精品影院| 国产精品一久久香蕉产线看| 巨大黑人极品VIDEOS精品| 麻豆精品不卡国产免费看| 综合人妻久久一区二区精品| 国产精品v欧美精品v日韩| 国产最新进精品视频| 亚洲国产精品一区二区第四页| 国产精品夜色视频一级区 | 无码人妻精品一区二区三区东京热| 国产成人精品久久亚洲| 成人久久精品一区二区三区| 蜜臀久久99精品久久久久久小说 | 久久九九亚洲精品| 99久久精品毛片免费播放| 日产欧美国产日韩精品| 日韩欧美一区二区三区中文精品 | 无码人妻精品一区二区三18禁| 欧美精品丝袜久久久中文字幕| 国产VA免费精品高清在线| 精品国产麻豆免费人成网站| 99国产精品久久久久久久成人热| 国产精品久久久久AV福利动漫| 久久99精品久久久久久hb无码| 亚洲AV无码成人精品区天堂| 亚洲综合av永久无码精品一区二区| 亚洲精品视频在线观看你懂的| 久久精品国产亚洲5555| 精品久久人人妻人人做精品| 国产精品热久久毛片| 国产精品成人国产乱一区| 国产精品乱码一区二区三区| 91精品在线国产| 国产精品免费αv视频| 国产综合精品蜜芽| 久久国产美女免费观看精品| 久久人人超碰精品CAOPOREN| 人妻少妇精品久久| 一区二区三区精品高清视频免费在线播放| 日韩精品国产自在欧美|