深入解析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

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

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

相關文章

Apache的認證、授權、訪問控制

原文鏈接&#xff1a; http://man.chinaunix.net/newsoft/Apache2.2_chinese_manual/howto/auth.html Apache認證、授權、訪問控制 認證(Authentication)是指任何識別用戶身份的過程。授權(Authorization)是允許特定用戶訪問特定區域或信息的過程。 相關模塊和指令 認證和授權…

黑馬C++設計模式2

簡單工廠模式 //一般來說&#xff0c;自己創建一個對象的方法是在自己寫的業務函數中直接new一個對象出來//但是現實需求&#xff0c;我不想創建對象&#xff0c;我只想拿來用。&#xff08;創建類的步驟比較復雜&#xff09; //好處&#xff0c;1、客戶端和具體實現類解耦。2…

[轉]Struts 2.1發布

作者 Ian Roughley譯者 崔康 發布于 2009年2月4日 上午8時13分 Struts2框架剛剛發布最新2.1版。該版本做了重大升級&#xff0c;包括重構更多代碼到插件框架、通過增加convention插件減少XML配置和改進REST支持。 我采訪了Musachy Barroso——該版本的一位開發人員&#xff0c…

dim private public static_PHP中const,static,public,private,protected的區別

const: 定義常量&#xff0c;一般定義后不可改變static: 靜態&#xff0c;類名可以訪問public: 表示全局&#xff0c;類內部外部子類都可以訪問&#xff1b;private: 表示私有的&#xff0c;只有本類內部可以使用&#xff1b;protected: 表示受保護的&#xff0c;只有本類或子類…

C#圖解教程 第六章 深入理解類

深入理解類 類成員 前兩章闡述了9種類成員中的兩種&#xff1a;字段和方法。本章將會介紹除事件(第14章)和運算符外的其他類成員&#xff0c;并討論其特征。 成員修飾符的順序 字段和方法的聲明可以包括許多如public、private這樣的修飾符。本章還會討論許多其他修飾符。多個修…

Apache用戶身份驗證

原文鏈接&#xff1a;http://www.yylog.org/?p4830 Apache用戶身份驗證 在apache應用過程中&#xff0c;管理員經常需要對apache下的目錄做一些限制&#xff0c;不希望所有用戶都能訪問該目錄下的文件&#xff0c;只對指定用戶訪問&#xff0c;此時我們就要用到apache用戶身…

攜程elong相繼牽手支付寶轉“危”為“機”

新華網浙江頻道1月16日電 自電子機票全面普及以來&#xff0c;航空公司機票直銷的力度不斷加強正給傳統的機票代理甚至在線旅游平臺帶來了極大的生存壓力。 而面對危機&#xff0c;在進一步豐富自身產品服務之外&#xff0c;大的在線旅行平臺也終于找到對策。繼eLong此前與支付…

c# 獲取word表格中的內容_Java 獲取、刪除Word文本框中的表格

本文介紹如何來獲取Word文本框中包含的表格&#xff0c;以及刪除表格。程序測試環境包括&#xff1a;IDEAJDK 1.8.0Spire.Doc.jar注&#xff1a;jar導入&#xff0c;可通過創建Maven程序項目&#xff0c;并在pom.xml中配置Maven倉庫路徑&#xff0c;并指定Free Spire.Doc for J…

Array.prototype.reduce 的理解與實現

Array.prototype.reduce 是 JavaScript 中比較實用的一個函數&#xff0c;但是很多人都沒有使用過它&#xff0c;因為 reduce 能做的事情其實 forEach 或者 map 函數也能做&#xff0c;而且比 reduce 好理解。但是 reduce 函數還是值得去了解的。 reduce 函數可以對一個數組進行…

PS摳圖方法[photoshop中文教程]

PS摳圖方法 一、魔術棒法——最直觀的方法   適用范圍&#xff1a;圖像和背景色色差明顯&#xff0c;背景色單一&#xff0c;圖像邊界清晰。   方法意圖&#xff1a;通過刪除背景色來獲取圖像。   方法缺陷&#xff1a;對散亂的毛發沒有用。   使用方法&#xff1a…

我的核心技術都是從哪里學到的?如何提高成長的?分享給大家。

1997年&#xff0c;我在讀黑龍江大學讀大二時&#xff0c;我認識了一個內蒙古大學計算機專業畢業的一個高材生&#xff0c;那時我那朋友引導了我很多&#xff0c;他那時候在我們家那邊開一個IT公司&#xff0c;他知道如何靠IT技術賺錢&#xff0c;如何靠程序等賺錢&#xff0c;…

python線性回歸算法簡介_Python實現的簡單線性回歸算法實例分析

本文實例講述了Python實現的簡單線性回歸算法。分享給大家供大家參考&#xff0c;具體如下&#xff1a; 用python實現R的線性模型(lm)中一元線性回歸的簡單方法&#xff0c;使用R的women示例數據&#xff0c;R的運行結果&#xff1a; > summary(fit) Call: lm(formula weig…

Object/Relation Mapping 對象關系映射

對象-關系映射&#xff08;Object/Relation Mapping&#xff0c;簡稱ORM&#xff09;&#xff0c;是隨著面向對象的軟件開發方法發展而產生的。面向對象的開發方法是當今企業級應用開發環境中的主流開發方法&#xff0c;關系數據庫是企業級應用環境中永久存放數據的主流數據存儲…

FastReport使用方法(C/S版)

前言 這兩天群里一直有群友問一些關于FastReport的問題&#xff0c;結合他們的問題&#xff0c;在這里做一個整理&#xff0c;有不明白的可以加 FastReport 交流群 群 號&#xff1a;554714044 工具 VS2017 FastReport 開始 1.新建項目&#xff0c;添加三個按鈕。預覽、設計、…

如何設置Linux時區為東八區

當我們購買美國VPS或服務器的時候&#xff0c;默認情況下是美國時間。對于我們定時執行某些任務會帶來麻煩&#xff0c;所以需要設置時區為東八區。登錄SSH后&#xff0c;執行tzselect命令。我們這里選擇亞洲5.這里選擇china 9。一般選東八區&#xff08;北京&#xff0c;廣東&…

python刪除兩個excel表中的相同元素_python篩選出兩個文件中重復行的方法

查找A文件中&#xff0c;與B文件中內容不重復的內容#!usr/bin/python import sys import os字符串查找函數&#xff0c;使用二分查找法在列表中進行查詢def binarySearch(value, lines): right len(lines) - 1 left 0 a value.strip() while left < right: middle int((…

求解:nhibernate2.0操作oralce提交事務時報錯

代碼如下: Configuration config new Configuration(); config.AddAssembly("TestCleanSnow"); ISessionFactory factory config.BuildSessionFactory(); ISession session f…

python畫楓葉_python-文件的操作

一、異常 程序在運行的過程中&#xff0c;不可避免出現一些錯誤&#xff0c;這些錯誤成為異常 異常以后的代碼都不會被執行 try 語句 代碼塊&#xff08;可能出現錯誤的語句&#xff09; except 異常類型 as 異常名: 代碼塊(出錯以后執行的語句&#xff09; except 異常類型 as…

記2018年技術人一次短暫的創業

背景 2018年8月底&#xff0c;我全職加入了一家創業公司&#xff0c;具體做什么我暫時先不說吧&#xff0c;我是產品和技術負責人&#xff0c;自己出資了50w&#xff0c;大股東&#xff08;下面簡稱T)也就是ceo是早期阿里出身的中供銷售&#xff0c;從2017年11月開始成立此公司…

如何在Apache環境下配置Rewrite規則

原文鏈接&#xff1a;http://faq.comsenz.com/viewnews-12 URL 靜態化是一個利于搜索引擎的設置&#xff0c;通過 URL 靜態化&#xff0c;達到原來是動態的 PHP 頁面轉換為靜態化的 HTML 頁面&#xff0c;當然&#xff0c;這里的靜態化是一種假靜態&#xff0c;目的只是提高搜…