文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

面试官:React事件绑定的方式有哪些?区别?

2024-12-03 02:21

关注

一、React事件绑定是什么

在react应用中,事件名都是用小驼峰格式进行书写,例如onclick要改写成onClick

最简单的事件绑定如下:

  1. class ShowAlert extends React.Component { 
  2.   showAlert() { 
  3.     console.log("Hi"); 
  4.   } 
  5.  
  6.   render() { 
  7.     return show; 
  8.   } 

从上面可以看到,事件绑定的方法需要使用{}包住

上述的代码看似没有问题,但是当将处理函数输出代码换成console.log(this)的时候,点击按钮,则会发现控制台输出undefined

二、如何绑定

为了解决上面正确输出this的问题,常见的绑定方式有如下:

render方法中使用bind

如果使用一个类组件,在其中给某个组件/元素一个onClick属性,它现在并会自定绑定其this到当前组件,解决这个问题的方法是在事件函数后使用.bind(this)将this绑定到当前组件中

  1. class App extends React.Component { 
  2.   handleClick() { 
  3.     console.log('this > ', this); 
  4.   } 
  5.   render() { 
  6.     return ( 
  7.       test
 
  •     ) 
  •   } 
  • 这种方式在组件每次render渲染的时候,都会重新进行bind的操作,影响性能

    render方法中使用箭头函数

    通过ES6的上下文来将this的指向绑定给当前组件,同样在每一次render的时候都会生成新的方法,影响性能

    1. class App extends React.Component { 
    2.   handleClick() { 
    3.     console.log('this > ', this); 
    4.   } 
    5.   render() { 
    6.     return ( 
    7.        this.handleClick(e)}>test
     
  •     ) 
  •   } 
  • constructor中bind

    在constructor中预先bind当前组件,可以避免在render操作中重复绑定

    1. class App extends React.Component { 
    2.   constructor(props) { 
    3.     super(props); 
    4.     this.handleClick = this.handleClick.bind(this); 
    5.   } 
    6.   handleClick() { 
    7.     console.log('this > ', this); 
    8.   } 
    9.   render() { 
    10.     return ( 
    11.       test 
    12.     ) 
    13.   } 

    定义阶段使用箭头函数绑定

    跟上述方式三一样,能够避免在render操作中重复绑定,实现也非常的简单,如下:

    1. class App extends React.Component { 
    2.   constructor(props) { 
    3.     super(props); 
    4.   } 
    5.   handleClick = () => { 
    6.     console.log('this > ', this); 
    7.   } 
    8.   render() { 
    9.     return ( 
    10.       test 
    11.     ) 
    12.   } 

    三、区别

    上述四种方法的方式,区别主要如下:

    编写方面:方式一、方式二写法简单,方式三的编写过于冗杂

    性能方面:方式一和方式二在每次组件render的时候都会生成新的方法实例,性能问题欠缺。若该函数作为属性值传给子组件的时候,都会导致额外的渲染。而方式三、方式四只会生成一个方法实例

    综合上述,方式四是最优的事件绑定方式

    参考文献

    https://segmentfault.com/a/1190000011317515

     

    https://vue3js.cn/interview/

     

    来源:JS每日一题内容投诉

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    软考中级精品资料免费领

    • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

      难度     813人已做
      查看
    • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

      难度     354人已做
      查看
    • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

      难度     318人已做
      查看
    • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

      难度     435人已做
      查看
    • 2024年上半年系统架构设计师考试综合知识真题

      难度     224人已做
      查看

    相关文章

    发现更多好内容

    猜你喜欢

    AI推送时光机
    位置:首页-资讯-后端开发
    咦!没有更多了?去看看其它编程学习网 内容吧
    首页课程
    资料下载
    问答资讯