搜索

查看: 3184|回复: 11

[JavaScript] Vue 事件处理函数的绑定示例详解

[复制链接]
发表于 2023-5-4 11:46:31 | 显示全部楼层 |阅读模式
Editor 2023-5-4 11:46:31 3184 11 看全部
目录
  • 正文
  • Vue 的事件处理绑定
  • 事件修饰符
  • 按键修饰符
  • Vue 为什么会在 HTML 中监听事件?
    正文
    在 JS 中「事件」是不需要绑定的,浏览器自带了许多的事件,每个事件都可以去绑定「处理器(处理函数)」。
    事件 ==> 用户行为 ==> 触发浏览器的事件 ==> 执行对应的事件处理函数
    我们通常通过addEventListenet方法去给事件绑定处理函数:
    document.addEventListenet("click", function () {
      // do...
    }, flase);
    需要注意的是addEventListenet只是「绑定」事件处理函数并不是「执行」!处理函数只会在对应事件触发的时候才会进行执行。
    某些情况下,我们需要把处理函数独立出去,并且需要更改this的执行,这是因为事件处理函数的this指向元素本身,也就意味着我们不能使用.call来更改this的指向,因为.call方法会立即执行函数!
    // 这会导致 test 立即执行!
    document.addEventListenet("click", test.call(this), flase);
    // 可以利用 .bind 方法放心的去指向 this,因为 bind 不会立即执行
    document.addEventListenet("click", test.bind(this), flase);

    Vue 的事件处理绑定
    来到Vue,Vue提供了v-on指令让开发者对元素绑定事件处理函数,例如:


    v-on的值可以是JS表达式:
    Add
    不推荐这样做,应该把逻辑放到methods里面处理。
    v-on的值还可以是一个方法事件处理器:
    Add
    @click接受一个方法名或对某个方法的调用。
    当通过方法名去绑定事件处理函数的时候,我们可以给方法传递参数:

      {{ count }}
      Add
      Minus

    以上代码,button在绑定了onClickAdd和onClickMinus处理函数后不会立即执行,而是当事件触发后才执行,这会开头我们说的addEventListenet是一样的!
    而onClickAdd和onClickMinus的括号是为了方便我们传递想要参数方便在methdos里进行处理。
    这里有一个特殊的参数$event,该属性是Vue内部封装的一个属性,表示触发事件的事件对象。
    const app = {
      template: `Minus`,
      data(){
        return {
          count: 0
        }
      }
      methods:{
        onClickMinus(num, e){
          console.log(e);
          this.count += num;
        }
      }
    }
    v-on指令还可以同时绑定多个事件处理函数,例如:

      {{ count }}
      Add
      Minus

    只要在两个方法的中间用,分隔就可以同时绑定两个事件处理函数啦。

    事件修饰符
    我们在处理事件时可能会调用event.preventDefault()或event.stopPropagation()是很常见的。Vue提供了一套「修饰符」来帮助我们完成这些事件,这么做的目的是让开发者更专注于数据逻辑而不用去处理DOM事件的细节。
    修饰符是用 . 表示的指令后缀,包含以下这些:
  • .stop:阻止事件冒泡。
  • .prevent:阻止事件的默认行为。
  • .self:当event.target是元素本身时才会触发事件处理器 。
  • .capture:采用事件捕获。
  • .once:事件调用一次后,自动移除监听器。
  • .passive:修饰符一般用于触摸事件的监听器,可以用来改善移动端设备的滚屏性能
    ⚠️ 注意
    不能同时使用.passive和.prevent,因为.passive已经向浏览器表明了你不想阻止事件的默认行为。
    如果你这么做了,则.prevent会被忽略,并且浏览器会抛出警告。







    ...
    使用修饰符时需要注意调用顺序,因为相关代码是以相同的顺序生成的。因此使用@click.prevent.self会阻止元素及其子元素的所有点击事件的默认行为,而@click.self.prevent则只会阻止对元素本身的点击事件的默认行为。

    按键修饰符
    我们通过可能还需要通过event.keycode来判断用户触发的按键,Vue允许在v-on或@监听按键事件时添加按键修饰符,例如:


    你可以直接使用KeyboardEvent.key暴露的按键名称作为修饰符,但需要转为 kebab-case 形式。

    Vue为一些常用的按键提供了别名:
  • .enter
  • .tab
  • .delete (捕获“Delete”和“Backspace”两个按键)
  • .esc
  • .space
  • .up
  • .down
  • .left
  • .right
    你可以使用以下系统按键修饰符来触发鼠标或键盘事件监听器,只有当按键被按下时才会触发。
  • .ctrl
  • .alt
  • .shift
  • .meta
    例如:



    Do something
    请注意,系统按键修饰符和常规按键不同。与keyup事件一起使用时,该按键必须在事件发出时处于按下状态。
    换句话说,keyup.ctrl只会在你仍然按住ctrl但松开了另一个键时被触发。若你单独松开ctrl键将不会触发。
    .exact修饰符允许控制触发一个事件所需的确定组合的系统按键修饰符。

    A

    A

    A
    你可以使用以下鼠标按键修饰符来触发鼠标事件监听器:
  • .left
  • .right
  • .middle
    这些修饰符将处理程序限定为由特定鼠标按键触发的事件。

    Vue 为什么会在 HTML 中监听事件?
    我们发现Vue是在template中直接绑定事件的,这违背了「关注点分离」的概念。但是不用担心,Vue把事件处理方法和表达式都严格的绑定到当前视图的ViewModel上,他不会导致任何维护上的困难。
    当我们使用v-on在视图上绑定事件处理,有几个好处:
    1、扫一眼HTML模版便能轻松定位JavaScript里面对应的方法。
    2、无须在JavaScript里手动绑定事件,你的ViewModel代码可以是非纯粹的逻辑,和DOM完全解藕,更容易测试。
    3、当一个ViewModel销毁的时候,所有的事件处理器都会自动被删除。你需要担心如何清理它们。
    以上就是Vue 事件处理函数的绑定示例详解的详细内容,更多关于Vue 事件处理函数绑定的资料请关注知鸟论坛其它相关文章!
  • 发表于 2023-6-29 15:30:59 | 显示全部楼层
    我是的十八簿 2023-6-29 15:30:59 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    发表于 2023-6-29 17:08:58 | 显示全部楼层
    永远爱你冰塘 2023-6-29 17:08:58 看全部
    这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
    发表于 2023-6-29 17:37:24 | 显示全部楼层
    哈哈SE7 2023-6-29 17:37:24 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    发表于 2023-6-29 23:22:05 | 显示全部楼层
    dxf17 2023-6-29 23:22:05 看全部
    其实我一直觉得楼主的品味不错!呵呵!知鸟论坛太棒了!
    发表于 2023-6-30 09:56:17 | 显示全部楼层
    xinting_6ym 2023-6-30 09:56:17 看全部
    论坛不能没有像楼主这样的人才啊!我会一直支持知鸟论坛。
    发表于 2023-6-30 10:16:02 | 显示全部楼层
    六翼天使494 2023-6-30 10:16:02 看全部
    这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
    发表于 2023-6-30 19:21:10 | 显示全部楼层
    向往草原403 2023-6-30 19:21:10 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    发表于 2023-7-3 06:46:44 | 显示全部楼层
    当当当当裤裆坦 2023-7-3 06:46:44 看全部
    论坛不能没有像楼主这样的人才啊!我会一直支持知鸟论坛。
    发表于 2023-7-3 08:48:24 | 显示全部楼层
    123456823 2023-7-3 08:48:24 看全部
    这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
    • 您可能感兴趣
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则 返回列表

    RSS订阅| 小黑屋| 知鸟论坛 |网站地图
    本站资源来自互联网用户收集发布,如有侵权请邮件联系处理。 联系邮箱E-mail:zniao@foxmail.com
    快速回复 返回顶部 返回列表