react函数this相关问题的示例

小编给大家分享一下react函数this相关问题的示例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

创新互联是一家专注于成都做网站、成都网站设计与策划设计,林周网站建设哪家好?创新互联做网站,专注于网站建设10余年,网设计领域的专业建站公司;建站业务涵盖:林周等地区。林周做网站价格咨询:18980820575

react 函数this相关

在使用react的过程中,常常因为函数的this问题导致执行结果不如预期。现梳理下这块的问题,先看代码:

import React from "react";

class MsgList extends React.PureComponent {
  render() {
    return (
      
    {this.props.list.map((item, index) => (
  • {item}
  • ))}
) } } export default class List extends React.Component { constructor(props) { super(props) this.state = { inputMsg: '', list: [123] } } handleInput = (val) => { this.setState({ inputMsg: val.target.value }) } handleSubmit = () => { const text = this.state.inputMsg if (text) { const msg = [...this.state.list, text] this.setState({ inputMsg: '', list: msg }) } } render() { return (

) } }

示例代码实现了简单的元素添加和列表展示功能。

其中函数绑定和定义的方式如下:

// 绑定
onChange={this.handleInput}
// 定义
handleInput = (val) => {
  this.setState({
    inputMsg: val.target.value
  })
}

定义函数的方式有很多种,比如:

handleInput(val) {
  console.log(val.target)
  console.log(this)
  this.setState({
    inputMsg: val.target.value
  })
}

此时val.target为元素,但是this为undefined,此时调用this.setState会报错。

react函数this相关问题的示例

类的方法默认是不会绑定this的,所以这里丢失了函数执行的上下文。那么如果在绑定时候加上一对括号:



// 函数定义
handleInput(val) {
  console.log(val.target)
  console.log(this)
  this.setState({
      inputMsg: val.target.value
  })
}

此时添加括号,虽然绑定了上下文,但这样会导致函数在组件渲染的时候被触发,而不是等到渲染完成时通过点击触发,且无法响应onChange动作。组件在渲染过程中触发函数,函数中调用setState()会再次调用render,导致死循环。

如果在最开始使用.bind()为函数绑定上下文,去掉绑定函数时的括号,

constructor(props) {
  super(props)
  this.state = {
    inputMsg: 'hello',
    list: [123]
  }
  this.handleInput = this.handleInput.bind(this)
}

这时功能正常。

而最开始我们定义函数时用箭头函数绑定了上下文,所以也能实现想要的功能。

除此之外,还有一种书写方式也可以正常工作,不过实际上与最开始的写法是一样的。

this.handleInput(e)}/>

使用react的时候要注意this的指向,类默认是不会为方法绑定this,要么在开始的时候手动绑定this,要么可以使用箭头函数自动绑定上下文。如果不是希望在组件渲染时就触发的函数,那么绑定函数时不能加括号。

以上是“react函数this相关问题的示例”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


本文标题:react函数this相关问题的示例
分享地址:http://myzitong.com/article/gdhhds.html