vue 事件中的 .native你搞清楚了吗

native是什么?

.native - 监听组件根元素的原生事件。 
主要是给自定义的组件添加原生事件。

官网的解释:

        你可能想在某个组件的根元素上监听一个原生事件。可以使用 v-on 的修饰符 .native 。

        通俗点讲:就是在父组件中给子组件绑定一个原生的事件,就将子组件变成了普通的HTML标签,不加'. native'事件是无法触 发的。

 <!DOCTYPE html>
 <html lang="en">
 <head>
      <meta charset="UTF-8">
      <title>Document</title>
  </head>
  <body>
      <div id="app">
          <button @click.native="clickFn">按钮</button>
      </div>
  <script src='vue.js'></script>
  <script>


      new Vue({
          el:'#app',
          data:{
          },
          methods:{
              clickFn () {
                console.log('点击按钮了')
            }
          }
      })
  
  </script>
  </body>
  </html>

  此时点击页面中的按钮无任何反应。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <div id="app">
        <card @click.native="clickFn">按钮</card>
    </div>
<script src='vue.js'></script>
<script>

    Vue.component('card',{
        template:'<p>这是card组件<button>按钮</button></p>'
    })

    new Vue({
        el:'#app',
        data:{
            state:false
        },
        methods:{
            clickFn (e) {
              console.log(e)  //打印出MouseEvent对象
              if (e.target.nodeName === 'IMG') {  // 可以对点击的target标签进行判断
                this.dialogImageUrl = file.target.src
                this.dialogVisible = true
              }
          }
        }
    })

</script>
</body>
</html>
 

总结: .native - 主要是给自定义的组件添加原生事件,可以理解为该修饰符的作用就是把一个vue组件转化为一个普通的HTML标签,并且该修饰符对普通HTML标签是没有任何作用的。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue ,`.native` 属性用于在组件上监听原生事件Vue 组件封装了一些自定义事件(如 `click`、`input` 等),这些事件是组件自身所触发的,而非原生 DOM 事件。如果我们需要监听原生 DOM 事件,可以使用 `.native` 修饰符来告诉 Vue 监听原生事件。 例如,假设我们有一个自定义组件 `MyButton`: ```vue <template> <button @click="onClick">Click me</button> </template> <script> export default { methods: { onClick() { this.$emit('click'); } } }; </script> ``` 这个组件封装了一个 `click` 事件,并通过 `$emit` 方法触发了该事件。如果我们在使用该组件时需要监听原生的 `click` 事件,就可以使用 `.native` 修饰符来实现: ```vue <template> <div> <my-button @click.native="onNativeClick"></my-button> </div> </template> <script> import MyButton from './MyButton.vue'; export default { components: { MyButton }, methods: { onNativeClick() { console.log('Native click event'); } } }; </script> ``` 在上面的代码,我们在 `my-button` 组件上使用了 `.native` 修饰符来监听原生的 `click` 事件,并在组件外部定义了一个 `onNativeClick` 方法来处理该事件。这样,当用户点击 `my-button` 组件时,就会触发原生的 `click` 事件,并调用 `onNativeClick` 方法。 需要注意的是,`.native` 修饰符只能用于组件自定义事件的监听,不能用于原生 DOM 事件的监听。如果需要监听原生 DOM 事件,应该直接在模板使用原生的事件监听器,例如 `@click`、`@input` 等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值