将原生事件绑定到组件2

v-on 的 .native 修饰符:

父:<base-input v-on:focus.native="onFocus"></base-input>

 

子:<label>

{{ label }}

<input

v-bind="$attrs"

v-bind:value="value"

v-on:input="$emit('input', $event.target.value)" >

</label>

父级的 .native 监听器将静默失败。

解决方案:

$listeners属性:

配合 v-on="$listeners"将所有的事件监听器指向这个组件的某个特定的子元素。

Vue.component('base-input', {

inheritAttrs: false,

props: ['label', 'value'],

computed: {

inputListeners: function () {

var vm = this

// `Object.assign` 将所有的对象合并为一个新对象

return Object.assign({},

// 我们从父级添加所有的监听器 this.$listeners,

this.$listeners,

// 然后我们添加自定义监听器,

// 或覆写一些监听器的行为

{

// 这里确保组件配合 `v-model` 的工作

input: function (event) {

vm.$emit('input', event.target.value)

}

}

) } },

template: `

<label>

{{ label }}

<input

v-bind="$attrs"

v-bind:value="value"

v-on="inputListeners" >

</label> ` })

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值