網站首頁 編程語言 正文
一、問題
例如 平常綁定事件我們一定會這么寫
//創建組件
class Demo extends React.Component{
state = {
name:'張三'
}
//展示左側輸入框的數據
showData(){
alert(this.state.name); //此時的this為undefined
}
render(){
return(
<div>
<button onClick={this.showData}>點我</button>
</div>
)
}
}
//渲染組件到頁面
ReactDOM.render(<Demo a="1" b="2"/>,document.getElementById('test'))
為什么this沒有指向當前類呢,其實很簡單 this 本質上就是指向它的調用者 所以自然指向不會是當前類
例如如下案例
//創建一個Person類
class Person {
//構造器方法
constructor(name,age){
this.name = name
this.age = age
}
speak(){
console.log(this);
}
}
const test = new Person('張三',19)
let speak = test.speak
test.speak() //當前實例
speak() //undefined
然而為什么是undefined不是window呢,因為class里面其實自帶嚴格模式,在babel轉義中也是嚴格模式的,如下圖 在頂端加上了 "use strict";這樣就開啟的嚴格模式,所以就為undefined,好奇的小伙伴也可以試試
function fn(){
"use strict";
console.log(this);
}
fn()
?二、解決問題
????????方法 一,用bind改變this指向
//創建組件
class Demo extends React.Component{
state = {
name:'張三'
}
//展示左側輸入框的數據
showData(){
alert(this.state.name);
}
render(){
return(
<div>
<button onClick={this.showData.bind(this)}>點我</button>
</div>
)
}
}
//渲染組件到頁面
ReactDOM.render(<Demo a="1" b="2"/>,document.getElementById('test'))
? ? ? ? 方法二,用es6的減頭函數this指向上一層?特性
//創建組件
class Demo extends React.Component{
state = {
name:'張三'
}
//展示左側輸入框的數據
showData = ()=>{
alert(this.state.name);
}
render(){
return(
<div>
<button onClick={this.showData}>點我</button>
</div>
)
}
}
//渲染組件到頁面
ReactDOM.render(<Demo a="1" b="2"/>,document.getElementById('test'))
額外在說說函數傳參把,這里不能像vue一樣,直接??onClick={this.showData('張三')} ,這樣的它綁定的是showData的返回值,從而不能這么寫
解決辦法
onClick={()=>this.showData('張三')} //方法一
onClick={this.showData.bind(this,'張三')} //方法二
原文鏈接:https://blog.csdn.net/qq_45689385/article/details/124218987
- 上一篇:React生命周期
- 下一篇:react 高價組件HOC實現組件復用
相關推薦
- 2022-09-19 C/C++最短路徑算法之迪杰斯特拉Dijkstra的實現詳解_C 語言
- 2022-08-19 python中的函數嵌套和嵌套調用_python
- 2022-07-04 如何生成對角矩陣?numpy.diag_python
- 2023-05-15 golang中的時間格式化_Golang
- 2022-06-21 Android?使用flow實現倒計時的方式_Android
- 2022-08-25 Python中的基本數據類型介紹_python
- 2022-06-08 記錄一次奇怪的springboot cache redis緩存報錯解決
- 2022-09-23 C#實現目錄跳轉(TreeView和SplitContainer)的示例代碼_C#教程
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支