码迷,mamicode.com
首页 > 其他好文 > 详细

记一次vue中自定义组件native的坑

时间:2020-06-17 11:02:45      阅读:68      评论:0      收藏:0      [点我收藏+]

标签:没有   temp   问题   pre   引用   遇到的问题   code   enter   htm   

?

vue之.native的作用

先描述一下自己开发中遇到的问题:

技术图片

最近在构建vue页面的时候,用到了输入框的enter事件,一开始@keyup.enter并没有加.native,所以这个enter事件总是不起作用。
技术图片

但是这种情况就可以不使用.native,因为是普通组件,不是自定义的组件。

为什么或出现这种情况呢?

组件绑定事件时:

1:普通组件绑定事件不能添加.native,添加事件后无效

2:自定义事件绑定事件需要添加.native,否则事件无效

.native原理:因为在自定义组件上注册的事件触发的是组件自定义的事件,主要是给自定义的组件添加原生事件

举例子:

<template>
  <button type="button" @click="clickHandler"><slot /></button>
</template>
export default {
  name: ‘button‘,
  methods: {
    clickHandler () {
      this.$emit(‘vclick‘) // 触发 `vclick` 事件
    }
  }
}

引用Button.vue组件

<vButton @click="clickHandler" @vclick="vClickHandler">按钮</vButton>
import vButton from ‘@/components/Button‘
export default {
  components: { vButton },
  methods: {
    clickHandler () {
      alert(‘onclick‘) // 此处不会执行 因为组件中未定义 `click` 事件
    },
    vClickHandler () {
      alert(‘onvclick‘) // 触发 `vclick` 自定义事件
    }
  }
}

如果将上面的@click改成@click.native也可以实现该事件,两个都可以点击

<vButton @click.navtive="clickHandler" @vclick="vClickHandler">按钮</vButton>

.native 修饰符就是用来注册元素的原生事件而不是组件自定义事件的

原文引用:https://segmentfault.com/q/1010000011186651/a-1020000011187890
https://www.cnblogs.com/qq254980080/p/10340487.html

记一次vue中自定义组件native的坑

标签:没有   temp   问题   pre   引用   遇到的问题   code   enter   htm   

原文地址:https://www.cnblogs.com/clover-forever/p/13150734.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!