vue-自定义指令传参

自定义指令传参

指令

在vue官网中,常用指令有v-model和v-bind,但是,如果我们需要对DOM元素进行底层操作,就需要用到自定义指令。
今天主要讲到传参的2种方式。

环境

  • vue2.3.3
  • node6.11.2
  • webpack2.6.1
    这里写图片描述
    这里写图片描述

传参方式

在main.js中定义一个指令。
Vue.directive('zoom', {
    bind: function (el, binding, vnode) {
        console.log(binding)
    },
    update: function (el) {
    },
    unbind: function (el) {
    }
})
使用自定义指令,在任意一个html元素中,使用指令。
<div v-zoom:{a:1,b:2}="{width: 800, height: 1000}"></div>

这里写图片描述

方式一:v-zoom:{a:1,b:2}
对于{a:1,b:2},在binding属性中,以字符串的形式传递,故可以写[1,2]、true等数据格式,但是最后拿到的都是字符串类型。
方式二:v-zoom="{width: 800, height: 1000}"
等号后面的{width: 800, height: 1000},可以在binding的value属性中获取的数据的类型没有变化,
可以直接使用。width后面的数字,可以用当前组件的参数替换。

参考

https://cn.vuejs.org/v2/guide/custom-directive.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值