<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答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
        主站蜘蛛池模板: 亚洲AV无码成人专区片在线观看 | 久久久久亚洲精品无码系列| 国产亚洲综合视频| 日韩免费毛片视频| 亚洲a∨国产av综合av下载| 日韩精品视频免费在线观看| 亚洲精品无码不卡在线播放| 午夜dj在线观看免费视频| 精品亚洲av无码一区二区柚蜜| 毛片视频免费观看| 亚洲а∨精品天堂在线| 四虎在线播放免费永久视频 | 亚洲AV无码不卡在线观看下载 | 亚洲AV无码一区二区三区系列| A片在线免费观看| 久久99国产亚洲精品观看| 麻豆高清免费国产一区| 亚洲日韩精品国产3区| 四虎永久免费网站免费观看| rh男男车车的车车免费网站| 情人伊人久久综合亚洲| 96免费精品视频在线观看| 亚洲高清一区二区三区| 免费人成网站7777视频| a级日本高清免费看| 亚洲伊人久久大香线蕉啊| 国产精品色午夜视频免费看| 在线观看免费黄色网址| 亚洲一区二区三区91| 免费一级国产生活片| av永久免费网站在线观看| 亚洲人成网站日本片| 亚洲AV成人精品日韩一区18p| 成人久久免费网站| 亚洲最大av资源站无码av网址| 国产一级淫片a免费播放口之| 成人妇女免费播放久久久| 国产成人亚洲合集青青草原精品| 免费一级毛片女人图片| 天天影院成人免费观看| jizz中国免费|