react事件处理函数中绑定this的bind()函数
问题引入
import React, { Component } from 'react'; import { Text, View } from 'react-native'; export default class App extends Component<Props> { constructor(props){ super(props) this.state={ times:0 } this.timePlus=this.timePlus.bind(this); } timePlus(){ let time=this.state.times time++ this.setState({ times:time }) } render() { return ( <View> <Text onPress={this.timePlus}>有本事点我呀</Text>
//<Text onPress={this.timePlus.bind(this)}>有本事点我呀</Text>
<Text>你点了我{this.state.times}次</Text> </View>
);
}
}
每次在处理事件函数时都需要绑定this的bind函数;
bind() 最简单的用法是创建一个函数,使这个函数不论怎么调用都有同样的 this 值。
bind()方法会创建一个新函数,当这个新函数被调用时,它的this值是传递给bind()的第一个参数, 它的参数是bind()的其他参数和其原本的参数.
this.x = 9; var module = { x: 81, getX: function() { return this.x; } }; module.getX(); // 返回 81 var retrieveX = module.getX; retrieveX(); // 返回 9, 在这种情况下,"this"指向全局作用域 // 创建一个新函数,将"this"绑定到module对象 var boundGetX = retrieveX.bind(module); boundGetX(); // 返回 81
从实例可以看出:React构造方法中的bind会将handleClick函数与这个组件Component进行绑定以确保在这个处理函数中使用this时可以时刻指向这一组件。
源码地址:https://github.com/zuobaiquan/react-native/tree/master/myExercise/firstProject