日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

深入解析react关于事件绑定this的四种方式

發布時間:2023/12/9 编程问答 59 豆豆
生活随笔 收集整理的這篇文章主要介紹了 深入解析react关于事件绑定this的四种方式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這篇文章主要介紹了詳解react關于事件綁定this的四種方式,寫的十分的全面細致,具有一定的參考價值,對此有需要的朋友可以參考學習下。如有不足之處,歡迎批評指正。

在react組件中,每個方法的上下文都會指向該組件的實例,即自動綁定this為當前組件,而且react還會對這種引用進行緩存,以達到cpu和內存的最大化。在使用了es6 class或者純函數時,這種自動綁定就不復存在了,我們需要手動實現this的綁定

React事件綁定類似于DOM事件綁定,區別如下:

  • 1.React事件的用駝峰法命名,DOM事件事件命名是小寫
  • 2.通過jsx,傳遞一個函數作為event handler,而不是一個字符串。
  • 3.React事件不能通過返回false來阻止默認事件,需要顯式調用preventDefault() 如下實例:
<a href="#" onclick="console.log('The link was clicked.'); return false"> Click me </a>class ActionLink extends React.Component { constructor(props) { super(props); }handleClick(e) { e.preventDefault(); console.log('The link was clicked.'); }//歡迎加入前端全棧開發交流圈一起學習交流:864305860render() { return ( <a href="#" onClick={this.handleClick.bind(this)}>Click Me...</a> ); }} 復制代碼

ps:React組件類的方法沒有默認綁定this到組件實例,需要手動綁定。 以下是幾種綁定的方法:

bind方法

直接綁定是bind(this)來綁定,但是這樣帶來的問題是每一次渲染是都會重新綁定一次bind;

class Home extends React.Component { constructor(props) {super(props);this.state = {};//歡迎加入前端全棧開發交流圈一起學習交流:864305860} del(){console.log('del')} render() {return (<div className="home"><span onClick={this.del.bind(this)}></span></div>);} } 復制代碼

構造函數內綁定

在構造函數 constructor 內綁定this,好處是僅需要綁定一次,避免每次渲染時都要重新綁定,函數在別處復用時也無需再次綁定

class Home extends React.Component { constructor(props) {super(props);this.state = { };//歡迎加入前端全棧開發交流圈一起學習交流:864305860this.del=this.del.bind(this)} del(){console.log('del')} render() {return (<div className="home"><span onClick={this.del}></span></div>);} } 復制代碼

::不能傳參

如果不傳參數使用雙冒號也是可以

class Home extends React.Component { constructor(props) {super(props);this.state = { };//歡迎加入前端全棧開發交流圈一起學習交流:864305860} del(){console.log('del')} render() {return (<div className="home"><span onClick={::this.del}></span></div>);} } 復制代碼

箭頭函數綁定

箭頭函數不僅是函數的'語法糖',它還自動綁定了定義此函數作用域的this,因為我們不需要再對它們進行bind方法:

class Home extends React.Component {constructor(props) {super(props);this.state = { }; //歡迎加入前端全棧開發交流圈一起學習交流:864305860} del=()=>{console.log('del')}render() {return (<div className="home"><span onClick={this.del}></span></div>);} } 復制代碼

以上幾種方法都可以實現this綁定,使用那種各自的習慣;希望對大家的學習有所幫助

結語

感謝您的觀看,如有不足之處,歡迎批評指正。

本次給大家推薦一個免費的學習群,里面概括移動應用網站開發,css,html,webpack,vue node angular以及面試資源等。 對web開發技術感興趣的同學,歡迎加入Q群:864305860,不管你是小白還是大牛我都歡迎,還有大牛整理的一套高效率學習路線和教程與您免費分享,同時每天更新視頻資料。 最后,祝大家早日學有所成,拿到滿意offer,快速升職加薪,走上人生巔峰。

轉載于:https://juejin.im/post/5c150b36f265da61524d4979

總結

以上是生活随笔為你收集整理的深入解析react关于事件绑定this的四种方式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。