vue的自定義指令傳參方式
自定義指令傳參
指令
在vue官網(wǎng)中,常用指令有v-model和v-bind,但是,如果我們需要對DOM元素進行底層操作,就需要用到自定義指令。
今天主要講到傳參的2種方式。
環(huán)境
- 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等數(shù)據(jù)格式,但是最后拿到的都是字符串類型。
方式二:v-zoom="{width: 800, height: 1000}"
- 等號后面的{width: 800, height: 1000},可以在binding的value屬性中獲取的數(shù)據(jù)的類型沒有變化,
- 可以直接使用。width后面的數(shù)字,可以用當(dāng)前組件的參數(shù)替換。
參考https://cn.vuejs.org/v2/guide/custom-directive.html
自定義指令動態(tài)參數(shù)
1. 通過自定義指令中的修飾符的key作為值,更改顯示的顏色
動態(tài)指令參數(shù)
當(dāng)參數(shù)是動態(tài)的時候。
main.js
//當(dāng)參數(shù)的值是動態(tài)的時候 Vue.directive('color2', { ? bind: function(el, binding) { ? ? el.style.color = binding.value; ? } }) Vue.directive('color3', { ? bind: function(el, binding) { ? ? el.style.color = binding.arg; ? } })
template.vue中
<template> <div class="demo"> ? <!-- value --> ? <p v-color2='purpleUser'><i class="el-icon-user-solid"></i></p> ? <p v-color2='redUser'><i class="el-icon-user-solid"></i></p> ? <p v-color2='greenUser'><i class="el-icon-user-solid"></i></p> ? <!-- arg --> ? <p v-color3:[purpleUser]><i class="el-icon-user-solid"></i></p> ? <p v-color3:[redUser]><i class="el-icon-user-solid"></i></p> ? <p v-color3:[greenUser]><i class="el-icon-user-solid"></i></p> </div> </template>
<script> export default { ? data() { ? ? return { ? ? ? purpleUser: 'purple', ? ? ? redUser: 'red', ? ? ? greenUser: 'green' ? ? } ? }, ? created() {}, ? methods: {} } </script>
<style lange='scss' scoped> p { ? display: inline-block; ? font-size: 40px; } </style>
參數(shù)是靜態(tài)的,將key的值作為value,改變顏色
main.js
Vue.directive('color', { ? bind: function(el, binding) { ? ? const color = Object.keys(binding.modifiers)[0]; //將key的值作為value,改變顏色,Object.keys獲取key的值; ? ? el.style.color = color; ? } })
template.vue中
<template> <div class="demo"> ? <p v-color.purple><i class="el-icon-user-solid"></i></p> ? <p v-color.red><i class="el-icon-user-solid"></i></p> ? <p v-color.green><i class="el-icon-user-solid"></i></p> </div> </template>
<script> export default { ? data() { ? ? return {} ? }, ? created() {}, ? methods: {} } </script>
<style lange='scss' scoped> p { ? display: inline-block; ? font-size: 40px; } </style>
以上的方法,最終實現(xiàn)效果是一樣的。
好了,這些僅為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
解決vue-cli創(chuàng)建項目的loader問題
下面小編就為大家分享一篇解決vue-cli創(chuàng)建項目的loader問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看看吧2018-03-03vue中實現(xiàn)在外部調(diào)用methods的方法(推薦)
下面小編就為大家分享一篇vue中實現(xiàn)在外部調(diào)用methods的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02vue2.0構(gòu)建單頁應(yīng)用最佳實戰(zhàn)
這篇文章主要為大家分享了vue2.0構(gòu)建單頁應(yīng)用最佳實戰(zhàn)案例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04