当前位置: 首页 > wzjs >正文

主流的外贸平台wordpress织梦seo

主流的外贸平台,wordpress织梦seo,婚礼视频制作软件,天津网站建设渠道目录 ‌1、错误写法‌:onClick{this.acceptAlls()} ‌2、正确写法‌:onClick{this.acceptAlls}(不带括号) 总结 方案1:构造函数绑定 方案2:箭头函数包装方法(更简洁) 方案3&am…

 

目录

‌1、错误写法‌:onClick={this.acceptAlls()}

‌2、正确写法‌:onClick={this.acceptAlls}(不带括号)

总结

方案1:构造函数绑定

方案2:箭头函数包装方法(更简洁)

方案3:直接绑定 + 参数传递

方案的关键区别说明


在写代码时,看到别人写的点击事件,大家写法都不太一样,到底有什么需要注意的呢?

-----------需要注意 ‌正确的绑定方式 和 ‌事件触发时机

‌1、错误写法‌:onClick={this.acceptAlls()}

     原因:

  • 这样写会‌立即执行‌ acceptAlls 函数,而不是在点击时执行。
  • 括号 () 表示函数调用
  • 组件渲染时就会执行 acceptAlls
  • onClick 实际上接收到的是 acceptAlls 的返回值(这里是 undefined),而不是函数本身
// 例如:错误的写法
class MyComponent extends React.Component {acceptAlls = () => {console.log("执行逻辑", this.props); //};
}<Button onClick={this.acceptAlls() }>保存</Button>

‌2、正确写法‌:onClick={this.acceptAlls}(不带括号)

// 改正后的:
class MyComponent extends React.Component {acceptAlls = () => {console.log("执行逻辑", this.props); //};
}<Button onClick={this.acceptAlls}>保存</Button>

总结

在 React 中,onClick 需要接收一个‌函数引用‌(即函数本身),而不是函数的执行结果

  • onClick={函数}‌:传递函数引用,点击时执行。
  • onClick={函数()}‌:立即执行函数,传递返回值(通常是无效的)。
  • 这里 () => {...} 创建了一个新函数,点击时才会调用 acceptAlls(id)

方案1:构造函数绑定

<Button onClick={this.acceptAlls }>保存</Button>

上述写法的前提需要:this指向要明确(要么手动绑定、要么写成箭头函数)

class MyComponent extends React.Component {// 方式1:构造函数中绑定constructor(props) {super(props);this.acceptAlls = this.acceptAlls.bind(this);  // !!!!!!}acceptAlls() {console.log("执行逻辑", this.props); // this 正确指向组件实例}<Button onClick={this.acceptAlls}>直接确认</Button >
}

class MyComponent extends React.Component {// 方式2:箭头函数自动绑定 thisacceptAlls = () => {console.log("执行逻辑", this.props); // this 始终正确};<Button onClick={this.acceptAlls}>直接确认</Button >
}

class MyComponent extends React.Component {constructor(props) {super(props);this.acceptAlls = this.acceptAlls.bind(this); // ✅ 正确绑定}acceptAlls(id) {console.log("执行ID:", id, this.props); // ✅ this 正确}render() {return (<Button onClick={() => this.acceptAlls(item.id)}>确认</Button>// ✅ 箭头函数传参 + 已绑定的方法);}
}

方案2:箭头函数包装方法(更简洁)

class MyComponent extends React.Component {// 箭头函数自动绑定 thisacceptAlls = (id) => {console.log("确认操作", id, this.props);};render() {return (<div>{/* 无参数 */}<Button onClick={this.acceptAlls}>直接确认</Button >{/* 有参数 */}// 需要传递额外参数时(如 id):<Button onClick={() => this.acceptAlls(item.id)}>确认</Button></div>);}
}

注意:

  • 箭头函数一定的性能影响‌,每次渲染都会创建新函数,可能影响性能(在循环或纯组件中慎用)‌

方案3:直接绑定 + 参数传递

class MyComponent extends React.Component {constructor(props) {super(props);this.acceptAlls = this.acceptAlls.bind(this);}acceptAlls(id) { /*...*/ }render() {return (<Button onClick={this.acceptAlls.bind(this, item.id)}>确认</Button>// ✅ bind 直接绑定参数(注意性能影响));}
}

方案的关键区别说明

方案this 绑定参数传递性能影响
构造函数绑定手动绑定需箭头函数传参最优
箭头函数方法自动绑定可箭头函数传参较优
直接bind传参手动绑定bind直接传参较差(每次渲染新建函数)

最佳实践建议

  1. 优先使用方案2(箭头函数方法)‌:既解决this问题,又保持代码简洁
  2. 需要兼容旧代码时用方案1‌:显式绑定更易理解
  3. 避免在render中直接bind‌(方案3):可能引发性能问题

 

 

http://www.dtcms.com/wzjs/552769.html

相关文章:

  • 网站建设zhuitiankejiwordpress租车主题
  • 现在做个网站多少钱淘宝关键词热度查询工具
  • 网站服务器网站建设费与网络维护费区别
  • 大兴智能网站建设哪家好网站建设对公司有什么意义
  • 如何免费做网站赚钱投资公司注册条件及经营范围
  • 网站建设需求模板wordpress文章数据库位置
  • 山东建设科技产品推广网站文明网站建设情况
  • 西安做公司网站公司国外网站做网站主播
  • 免费做推广的网站google关键词查询工具
  • 网站防黑客入侵做相关防御教你如何建设网站阿里去
  • 哪有做企业网站下载ppt模板免费
  • 网站页面设计的特色天津seo推广软件
  • 公司建设门户网站的意义wordpress nextpage
  • 网站响应时间长怎么自己做淘宝客网站
  • 徐汇区网站建设做网站如何赚广费
  • 网站做适配网站设置快捷方式
  • asp.net做的网站要放到网上空间去要放哪些文件上去免费网站赚钱
  • 自己动手做网站教程微博 分享 wordpress
  • 南京建站方案做下载网站挣钱吗
  • 化妆品行业网站开发app网站公司名称
  • 房产中介如何做网站代表网站开发的logo
  • 个人做网站法律风险汕头免费建站哪里有
  • 东莞网站网站的登陆注册页面怎么做
  • 筑云网站投诉建设信用卡网站登录
  • 朝阳网站建设公司电话建筑工程网上超市
  • 佛山有那些定制网站建设公司做网站字体要求
  • 关于网站建设的通知案例学 网页设计与网站建设
  • 网站源码带数据湖南土建网
  • 滨海做网站哪家好邢台网站建设制作
  • 公众号制作模板网站进入公众号广西医保