網站首頁 編程語言 正文
一、問題
例如 平常綁定事件我們一定會這么寫
//創建組件
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實現組件復用
相關推薦
- 2021-12-19 Linux下wget命令詳細介紹_Linux
- 2022-09-19 Redis緩存穿透/擊穿工具類的封裝_Redis
- 2022-05-20 plotly分割顯示mnist的方法詳解_python
- 2022-08-30 五個Python命令使用的小妙招分享_python
- 2022-04-27 Python中python-nmap模塊的使用介紹_python
- 2021-11-12 C/C++?Qt?StatusBar底部狀態欄應用教程_C 語言
- 2022-08-03 C++?sort排序函數用法詳解_C 語言
- 2022-04-08 Unity?UGUI?按鈕綁定事件的?4?種方式匯總_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同步修改后的遠程分支