Vue的$event的不同表现

$event 是事件对象的特殊变量,在两种场景下,它有不同的意义,代表不同的对象。

  • 在原生事件中表示事件本身。可以通过$event.target获得事件所在的DOM对象,再通过value进一步获取具体的值。
<template>
    <div>
        <input type="text" @input="inputHandler('hello', $event)" />
    </div>
</template>


export default {
    methods: {
        inputHandler(msg, e) {
            console.log(e.target.value)
        }
    }
}
  • 而在父子组件通过自定义事件进行通信时,表示从子组件中传递出来的参数值

看下面的例子:

//blog-post组件的模板

<button v-on:click="$emit('enlarge-text', 0.1)">
  Enlarge text
</button>

在父级组件监听这个事件的时候,可以通过 $event 访问到blog-post子组件传递出来的0.1这个值:

<blog-post
  ...
  v-on:enlarge-text="postFontSize += $event"
></blog-post>

此时,$event的值就是0.1,而不是前面的事件对象。

猜你喜欢

转载自blog.csdn.net/weixin_43844696/article/details/107401813