Vue.js列表渲染綁定jQuery插件的正確姿勢
使用v-for綁定列表時(shí),有時(shí)候需要綁定如select2之類的jQuery插件。
需要在Vue根據(jù)數(shù)組內(nèi)容生成dom元素之后,去找到該dom元素,然后 $().xxx綁定jQuery插件。
之前使用Vue.nextTick方法,在一次dom更新以后執(zhí)行延遲回調(diào),渲染jQuery插件。
然而這并不是一種很好的方式,有時(shí)候難以確定dom元素更新是否是我們需要關(guān)注的那個(gè)。
在列表中渲染Jquery插件的正確姿勢,是使用自定義指令。自定義指令提供了一些鉤子函數(shù),可以準(zhǔn)確的監(jiān)聽到dom元素與數(shù)據(jù)的綁定周期。
鉤子函數(shù)
指令定義函數(shù)提供了幾個(gè)鉤子函數(shù)(可選):
bind: 只調(diào)用一次,指令第一次綁定到元素時(shí)調(diào)用,用這個(gè)鉤子函數(shù)可以定義一個(gè)在綁定時(shí)執(zhí)行一次的初始化動作。
inserted: 被綁定元素插入父節(jié)點(diǎn)時(shí)調(diào)用(父節(jié)點(diǎn)存在即可調(diào)用,不必存在于 document 中)。
update: 被綁定元素所在的模板更新時(shí)調(diào)用,而不論綁定值是否變化。通過比較更新前后的綁定值,可以忽略不必要的模板更新(詳細(xì)的鉤子函數(shù)參數(shù)見下)。
componentUpdated: 被綁定元素所在模板完成一次更新周期時(shí)調(diào)用。
unbind: 只調(diào)用一次, 指令與元素解綁時(shí)調(diào)用。
接下來我們來看一下鉤子函數(shù)的參數(shù) (包括 el,binding,vnode,oldVnode) 。
鉤子函數(shù)參數(shù)
鉤子函數(shù)被賦予了以下參數(shù):
el: 指令所綁定的元素,可以用來直接操作 DOM 。
binding: 一個(gè)對象,包含以下屬性:
- name: 指令名,不包括 v- 前綴。
- value: 指令的綁定值, 例如: v-my-directive="1 + 1", value 的值是 2。
- oldValue: 指令綁定的前一個(gè)值,僅在 update 和 componentUpdated 鉤子中可用。無論值是否改變都可用。
- expression: 綁定值的字符串形式。 例如 v-my-directive="1 + 1" , expression 的值是 "1 + 1"。
- arg: 傳給指令的參數(shù)。例如 v-my-directive:foo, arg 的值是 "foo"。
- modifiers: 一個(gè)包含修飾符的對象。 例如: v-my-directive.foo.bar, 修飾符對象 modifiers 的值是 { foo: true, bar: true }。
vnode: Vue 編譯生成的虛擬節(jié)點(diǎn),查閱 VNode API 了解更多詳情。
oldVnode: 上一個(gè)虛擬節(jié)點(diǎn),僅在 update 和 componentUpdated 鉤子中可用。
例子
<table id="testTable"> <tr v-for="(el, lineIndex) in lines" v-line-inserted="lineIndex" > <td> <input name="bindSelect2" /> <td> </tr> </table>
function renderLines(el, lineIndex){ //渲染select2 $("testTable tr").eq(lineIndex).select2({...}); } Vue.directive('line-inserted', { inserted: function (el, binding) { var lineIndex = binding.value; renderLines(el, lineIndex); } });
詳情參見Vue官方文檔自定義指令
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue實(shí)現(xiàn)手機(jī)端省市區(qū)區(qū)域選擇
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)手機(jī)端省市區(qū)區(qū)域選擇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09Element-UI Table組件上添加列拖拽效果實(shí)現(xiàn)方法
這篇文章主要為大家詳細(xì)介紹了Element-UI Table組件上添加列拖拽效果的實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04vue實(shí)現(xiàn)實(shí)時(shí)搜索顯示功能
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)實(shí)時(shí)搜索顯示功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04客戶端(vue框架)與服務(wù)器(koa框架)通信及服務(wù)器跨域配置詳解
本篇文章主要介紹了客戶端(vue框架)與服務(wù)器(koa框架)通信及服務(wù)器跨域配置詳解,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08詳解使用Vue Router導(dǎo)航鉤子與Vuex來實(shí)現(xiàn)后退狀態(tài)保存
本篇文章主要介紹了詳解使用Vue Router導(dǎo)航鉤子與Vuex來實(shí)現(xiàn)后退狀態(tài)保存,具有一定的參考價(jià)值,有興趣的可以了解一下2017-09-09