搜索
您的当前位置:首页正文

React中this丢失的四种解决方法

来源:哗拓教育
React中this丢失的四种解决⽅法

发现问题

我们在给⼀个dom元素绑定⽅法的时候,例如:

React组件中不能获取refs的值,页⾯报错提⽰:Uncaught TypeError: Cannot read property 'refs' of null or undefind⼩栗⼦

import React from 'react';import $ from 'jquery'import '../app.scss';

export default class MyForm extends React.Component { submitHandler (event) { event.preventDefault();

console.log(this.refs.helloTo);

var helloTo = this.refs.helloTo.value; alert(helloTo); }

render () { return (

) }}

React中的bind同上⽅原理⼀致,在JSX中传递的事件不是⼀个字符串,⽽是⼀个函数(如:onClick={this.handleClick}),此时onClick即是中间变量,所以处理函数中的this指向会丢失。解决这个问题就是给调⽤函数时bind(this),从⽽使得⽆论事件处理函数如何传递,this指向都是当前实例化对象。解决

解决⽅案有4种

1、在ES6中可以在构造函数中,直接将当前组件(或者叫类)的实例与函数绑定。2、在⽅法调⽤的时候绑定this

如: 3、在⽅法编写结尾的时候绑定this,bind(this)如:

submitHandler(){ console.log(1)}.bind(this)

4、使⽤es6 箭头函数 myfn = () =>{ console.log(this.refs.can) }

推荐使⽤箭头函数,因为最近刚换到react 来,没怎么看就直接cli 来怼,遇到⼀些⼩问题记录于此总结

以上就是这篇⽂章的全部内容了,希望本⽂的内容对⼤家的学习或者⼯作具有⼀定的参考学习价值,谢谢⼤家对的⽀持。

因篇幅问题不能全部显示,请点此查看更多更全内容

Top