欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue.js列表渲染綁定jQuery插件的正確姿勢

 更新時間:2017年06月29日 10:19:17   投稿:lijiao  
這篇文章主要為大家詳細介紹了Vue.js列表渲染綁定jQuery插件的正確姿勢,具有一定的參考價值,感興趣的小伙伴們可以參考一下

使用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 鉤子中可用。 

例子

<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官方文檔自定義指令

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • uniapp中uni-load-more的使用方式

    uniapp中uni-load-more的使用方式

    這篇文章主要介紹了uniapp中uni-load-more的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • vue實現手機端省市區(qū)區(qū)域選擇

    vue實現手機端省市區(qū)區(qū)域選擇

    這篇文章主要為大家詳細介紹了vue實現手機端省市區(qū)區(qū)域選擇,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • Vue中mixins的使用方法詳解

    Vue中mixins的使用方法詳解

    mixins是一種分發(fā) Vue 組件中可復用功能的使用方式,它是一個 js 對象,包含我們組件script中的任意功能選項,下面就跟隨小編一起來看看它的具體使用吧
    2024-03-03
  • Element-UI Table組件上添加列拖拽效果實現方法

    Element-UI Table組件上添加列拖拽效果實現方法

    這篇文章主要為大家詳細介紹了Element-UI Table組件上添加列拖拽效果的實現方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • Vue3使用JSX的方法實例(筆記自用)

    Vue3使用JSX的方法實例(筆記自用)

    以前我們經常在react中使用jsx,現在我們在vue中也是用jsx,下面這篇文章主要給大家介紹了關于Vue3使用JSX的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • vue實現實時搜索顯示功能

    vue實現實時搜索顯示功能

    這篇文章主要為大家詳細介紹了vue實現實時搜索顯示功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 一文帶你了解Vue?和?React的區(qū)別

    一文帶你了解Vue?和?React的區(qū)別

    這篇文章主要介紹了Vue和React的區(qū)別,畢竟是兩個框架,不像兩個?API,要說細節(jié)上的區(qū)別就太多太多了,本文就簡單的帶大家說說Vue?和?React?的區(qū)別,需要的朋友可以參考下
    2023-05-05
  • vue生成gzip壓縮包部署到nginx的示例

    vue生成gzip壓縮包部署到nginx的示例

    vue 生成gzip壓縮包部署到nginx服務器,如果我們把web網站資源進行gzip壓縮后進行傳輸給瀏覽器,這樣就能加快網站資源的加載速度,這篇文章主要介紹了vue生成gzip壓縮包部署到nginx,需要的朋友可以參考下
    2022-12-12
  • 客戶端(vue框架)與服務器(koa框架)通信及服務器跨域配置詳解

    客戶端(vue框架)與服務器(koa框架)通信及服務器跨域配置詳解

    本篇文章主要介紹了客戶端(vue框架)與服務器(koa框架)通信及服務器跨域配置詳解,具有一定的參考價值,有興趣的可以了解一下
    2017-08-08
  • 詳解使用Vue Router導航鉤子與Vuex來實現后退狀態(tài)保存

    詳解使用Vue Router導航鉤子與Vuex來實現后退狀態(tài)保存

    本篇文章主要介紹了詳解使用Vue Router導航鉤子與Vuex來實現后退狀態(tài)保存,具有一定的參考價值,有興趣的可以了解一下
    2017-09-09

最新評論