上往建站提供服务器空间服务商,百度快照排名,网站托管,百度推广运营,致力于设计外包服务与源代码定制开发,360推广,搜狗推广,增加网站的能见度及访问量提升网络营销的效果,主营:网站公司,百度推广公司电话,官网搭建服务,网站服务企业排名,服务器空间,英文域名等业务,专业团队服务,效果好。
青海爱采购会员/58同城会员账户/百度竞价开户/百家号注册运营/推广公司网站-网站营销全网推广

常我们会为事件处理程序传递额外的参数。例如,若是 id 是你要删除那一行的 id,以下两种方式都可以向事件处理程序传递参数:
<button onClick={(e) => this.deleteRow(id, e)}>Delete Row</button><button onClick={this.deleteRow.bind(this, id)}>Delete Row</button>上述两种方式是等价的。
上面两个例子中,参数 e 作为 React 事件对象将会被作为第二个参数进行传递。通过箭头函数的方式,事件对象必须显式的进行传递,但是通过 bind 的方式,事件对象以及更多的参数将会被隐式的进行传递。
值得注意的是,通过 bind 方式向监听函数传参,在类组件中定义的监听函数,事件对象 e 要排在所传递参数的后面,例如:
class Popper extends React.Component{
constructor(){
super(); this.state = {name:'Hello world!'}; }
preventPop(name, e){
e.preventDefault(); alert(name); }
render(){
return (
<div>
<p>hello</p> {}
<a href="https://reactjs.org" onClick={this.preventPop.bind(this,this.state.name)}>Click</a>
</div> ); }}
3 篇笔记 写笔记
参考地址
4年前 (2018-07-26)
YuCun Zhong
www***26613280@qq.com
参考地址
34
理解 React 中 es6 创建组件 this 的方法
在JavaScript中,this对象是运行时基于函数的执行环境(也就是上下文)绑定的。
从 react 中的 demo 说起
Facebook最近一次更新react时,将es6中的class加入了组件的创建方式当中。Facebook也推荐组件创建使用通过定义一个继承自 React.Component 的class来定义一个组件类。官方的demo:
class LikeButton extends React.Component {
constructor() {
super();
this.state = {
liked: false
};
this.handleClick = this.handleClick.bind(this);
}
handleClick() {
this.setState({liked: !this.state.liked});
}
render() {
const text = this.state.liked ? 'liked' : 'haven't liked';
return (
<div onClick={this.handleClick}>
You {text} this. Click to toggle.
</div>
);
}
}
ReactDOM.render(
<LikeButton />,
document.getElementById('example')
);
上面的demo中有大量this的使用,在 class LikeButton extends React.Component 中我们是声明该class,因为this具体是由其上下文决定的,因此在类定义中我们无法得知this用法。 相当于是new了上面定义的类,首先调用 constructor() 函数, this.state 的this上下文就是该实例对象;同理,render() 函数中 this.state.liked 的this上下文也是该对象。问题在于 onClick={this.handleClick} ,获取该函数引用是没有问题,这里的this上下文就是该对象。
这时问题来了,在原来 React.createClass 中, handleClick() 在onClick事件触发的时候,会自动绑定到LikeButton实例上,这时候该函数的this的上下文就是该实例。不过在ES6的class的写法中,Facebook取消了自动绑定,实例化LikeButton后,handleClick()的上下文是div的支撑实例( backing instance ),而 handleClick() 原本要绑定的上下文是LikeButton的实例。对于该问题,我们有多种解决方案。
使用 bind() 函数改变 this 的上下文
可以在class声明中的constructor()函数中,使用:
this.handleClick = this.handleClick.bind(this);
该方法是一个bind()绑定,多次使用。在该方法中,我们在声明该实例后,可以在该实例任何地方使用 handleClick() 函数,并且该 handleClick() 函数的this的上下文都是LikeButton实例对象。
除此我们也可以在具体使用该函数的地方绑定this的上下文到LikeButton实例对象,代码如下:
<div onClick={this.handleClick.bind(this)}>
You {text} this. Click to toggle.
</div>
这种方法需要我们每次使用bind()函数绑定到组件对象上。
es6的箭头函数
es6中新加入了箭头函数=>,箭头函数除了方便之外还有而一个特征就是将函数的this绑定到其定义时所在的上下文。这个特征也可以帮助我们解决这个问题。使用如下代码:
<div onClick={() => this.handleClick()}>
You {text} this. Click to toggle.
</div>
这样该 this.handleClick() 的上下文就会被绑定到 LikeButton 的实例对象上。个人认为,使用箭头函数使得 JavaScript 更加接近面向对象的编程风格。
this 的总结
this 的本质就是:this跟作用域无关的,只跟执行上下文有关。
YuCun Zhong
YuCun Zhong
www***26613280@qq.com
参考地址
4年前 (2018-10-20)
阿星
192***540@qq.com
34
React 事件中 this 的三种使用方式
1.bind绑定的方法
不传参
class Hello extends React.Component{
constructor(){
super()
this.state = {
content:true
}
this.change = this.change.bind(this)
}
change(){
this.setState({
content:!this.state.content
})
}
render(){
return (
<div>
<h1>{this.state.content ? '1':'2'}</h1>
<h2>{this.props.name}</h2>
<button onClick={this.change}>
点击
</button>
</div>
)
}
}
ReactDOM.render(
<Hello name="Hello"/>,
document.getElementById('example')
)
传参
class Hello extends React.Component{
constructor(){
super()
this.state = {
content:true
}
this.change = this.change.bind(this,this.state.content)
}
change(obj){
this.setState({
content:!this.state.content
})
console.log(obj)
console.log(this.state.content)
}
render(){
return (
<div>
<h1>{this.state.content ? '1':'2'}</h1>
<h2>{this.props.name}</h2>
<button onClick={this.change}>
青海爱采购会员/58同城会员账户/百度竞价开户/百家号注册运营/推广公司网站-网站营销全网推广
上往建站提供搭建网站,域名注册,官网备案服务,网店详情页设计,企业网店,专业网络店铺管理运营全托管公司咨询电话,服务器空间,微信公众号托管,网页美工排版,致力于域名申请,竞价托管,软文推广,全网营销,提供标准级专业技术保障,了却后顾之忧,主营:虚拟主机,网站推广,百度竞价托管,网站建设,上网建站推广服务,网络公司有哪些等业务,专业团队服务,效果好。
服务热线:400-111-6878 手机微信同号:18118153152(各城市商务人员可上门服务)
阿珂
pin***affie2018@gmail.com
参考地址
React 点击事件的 bind(this) 如何传参?
需要通过 bind 方法来绑定参数,第一个参数指向 this,第二个参数开始才是事件函数接收到的参数:
<button onClick={this.handleClick.bind(this, props0, props1, ...}></button> handleClick(porps0, props1, ..., event) { // your code here }事件:this.handleclick.bind(this,要传的参数)
函数:handleclick(传过来的参数,event)
从 render 中传递参数到 外部函数 one():
class Ex extends React.Component{.... this.state={name:'Stupid Dog'};... ... ...function one(para){ console.log('parameter in one Func',para);}... ... ...render(){ var mm='AABB'; return (<div><button onClick={this.one.bind(this,mm)}> test</button> <button onClick={this.one.bind(this,this.state.name)}> test</button></div>);}}阿珂
pin***affie2018@gmail.com
参考地址
YuCun Zhong
www***26613280@qq.com
参考地址
理解 React 中 es6 创建组件 this 的方法
在JavaScript中,this对象是运行时基于函数的执行环境(也就是上下文)绑定的。
从 react 中的 demo 说起
Facebook最近一次更新react时,将es6中的class加入了组件的创建方式当中。Facebook也推荐组件创建使用通过定义一个继承自 React.Component 的class来定义一个组件类。官方的demo:
class LikeButton extends React.Component { constructor() { super(); this.state = {