這篇文章給大家分享的是有關Vue.js列表渲染綁定jQuery插件的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
創(chuàng)新互聯公司是一家集網站建設,梨林企業(yè)網站建設,梨林品牌網站建設,網站定制,梨林網站建設報價,網絡營銷,網絡優(yōu)化,梨林網站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯網需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網站。
使用v-for綁定列表時,有時候需要綁定如select2之類的jQuery插件。
需要在Vue根據數組內容生成dom元素之后,去找到該dom元素,然后 $().xxx綁定jQuery插件。
之前使用Vue.nextTick方法,在一次dom更新以后執(zhí)行延遲回調,渲染jQuery插件。
然而這并不是一種很好的方式,有時候難以確定dom元素更新是否是我們需要關注的那個。
在列表中渲染Jquery插件的正確姿勢,是使用自定義指令。自定義指令提供了一些鉤子函數,可以準確的監(jiān)聽到dom元素與數據的綁定周期。
鉤子函數
指令定義函數提供了幾個鉤子函數(可選):
bind:只調用一次,指令第一次綁定到元素時調用,用這個鉤子函數可以定義一個在綁定時執(zhí)行一次的初始化動作。
inserted:被綁定元素插入父節(jié)點時調用(父節(jié)點存在即可調用,不必存在于 document 中)。
update:被綁定元素所在的模板更新時調用,而不論綁定值是否變化。通過比較更新前后的綁定值,可以忽略不必要的模板更新(詳細的鉤子函數參數見下)。
componentUpdated:被綁定元素所在模板完成一次更新周期時調用。
unbind:只調用一次, 指令與元素解綁時調用。
接下來我們來看一下鉤子函數的參數 (包括 el,binding,vnode,oldVnode) 。
鉤子函數參數
鉤子函數被賦予了以下參數:
el:指令所綁定的元素,可以用來直接操作 DOM 。
binding:一個對象,包含以下屬性:
name: 指令名,不包括 v- 前綴。
value: 指令的綁定值, 例如: v-my-directive="1 + 1", value 的值是 2。
oldValue: 指令綁定的前一個值,僅在 update 和 componentUpdated 鉤子中可用。無論值是否改變都可用。
expression: 綁定值的字符串形式。 例如 v-my-directive="1 + 1" , expression 的值是 "1 + 1"。
arg: 傳給指令的參數。例如 v-my-directive:foo, arg 的值是 "foo"。
modifiers: 一個包含修飾符的對象。 例如: v-my-directive.foo.bar, 修飾符對象 modifiers 的值是 { foo: true, bar: true }。
vnode:Vue 編譯生成的虛擬節(jié)點,查閱 VNode API 了解更多詳情。
oldVnode:上一個虛擬節(jié)點,僅在 update 和 componentUpdated 鉤子中可用。
例子
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.js列表渲染綁定jQuery插件的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!