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

Vue.js結(jié)合SortableJS實(shí)現(xiàn)樹形數(shù)據(jù)拖拽

 更新時間:2023年05月08日 10:55:35   作者:i東東  
本文主要介紹了Vue.js結(jié)合SortableJS實(shí)現(xiàn)樹形數(shù)據(jù)拖拽,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

需求

表格實(shí)現(xiàn)行拖拽,要求只支持同級拖拽!

實(shí)現(xiàn)

使用插件:SortableJS,可以參考官網(wǎng)配置項!

// 安裝
npm install sortablejs --save
// 引入
import Sortable from 'sortablejs';
//my-table組件中
// 排序功能
setDragSort() {
//獲取需要添加拖拽的組件
  const el =
      this.$refs.elTable &&
      this.$refs.elTable.$el.querySelector(
        '.el-table__body-wrapper > table > tbody'
      )
// 判斷是props傳遞的參數(shù)(是否開啟拖拽,拖拽結(jié)束的方法,拖拽的組件)是否存在
  if (this.draggable && this.onDragEnd && el) {
    if (this.dragSort) this.dragSort.destroy() // 防止在Dom上重復(fù)綁定事件
    this.dragSort = sortablejs.create(el, {
      onEnd: (evt) => this.onDragEnd(evt),
      handle: this.handle ? `.${this.handle}` : '', // 可以拖拽的手柄,傳入的為類名
      filter: '.el-input, .el-textarea', // 過濾器,不需要進(jìn)行拖動的元素
      preventOnFilter: false, // 在觸發(fā)過濾器`filter`的時候調(diào)用`event.preventDefault()`
      ghostClass: 'sortable-ghost'
    })
  }
}

image.png

避坑(樹形結(jié)構(gòu)導(dǎo)致下標(biāo)錯亂)

如上代碼,就可以在頁面進(jìn)行推拽了,但是因?yàn)槭菢湫谓Y(jié)構(gòu),所以拖拽結(jié)束的時候拿到的下標(biāo)可能或錯亂,這個時候就需要將數(shù)據(jù)打平,在進(jìn)行拿值。

// 將樹數(shù)據(jù)轉(zhuǎn)化為平鋪數(shù)據(jù)
treeToTile(treeData, childKey = 'children') {
  const arr = []
  const expanded = data => {
    if (data && data.length > 0) {
      data.filter(d => d).forEach(e => {
        arr.push(e)
        expanded(e[childKey] || [])
      })
    }
  }
// 拖拽結(jié)束
async handleNodeDrag(evt) {
  const { newIndex, oldIndex } = evt
  // 把樹形的結(jié)構(gòu)轉(zhuǎn)為列表再進(jìn)行處理
  const activeRows = this.treeToTile(this.table.data)
  const oldData = activeRows[oldIndex]
  const newData = activeRows[newIndex]
},

通過平鋪之后就可以正常拿到拖拽前后的正確的下標(biāo)了,這樣就可以進(jìn)行下一步的操作了(提交更改到后端-->重新獲取數(shù)據(jù)-->渲染頁面)

避坑(樹形結(jié)構(gòu)導(dǎo)致拖拽父級子級數(shù)據(jù)不跟隨父級移動)

image.png

如上圖,拖拽之后子級數(shù)據(jù)并沒有跟隨父級,這樣就導(dǎo)致頁面顯示不正確,解決方法:首先想到的當(dāng)然既然已經(jīng)拖拽成功,那么肯定直接像后端獲取數(shù)據(jù)來進(jìn)行表格的刷新,但是試了一下表格并沒有更新,因?yàn)槲抑皇歉淖兞隧樞?其他所有內(nèi)容都沒有變,就導(dǎo)致Vue是通過虛擬DOM的比較來進(jìn)行頁面的更新,所以頁面并不會因?yàn)楂@取了數(shù)據(jù)而更新,所以這時候就需要對key值進(jìn)行操作了。

// 方法1
$forceUpdate
需要謹(jǐn)慎使用。 原因:它會強(qiáng)制整個組件的渲染,如果頻度沒有控制好,會一直渲染,導(dǎo)致應(yīng)用性能變得很低!!(不過我用的不生效,不知道為啥)
// 方法2
 this.key = Symbol(new Date().toString())
 簡單粗暴,直接給生成新的唯一值!?。√行Ч?/pre>

至此,表格刷新完成,但是新的BUG隨之而來....

避坑(刷新表格導(dǎo)致抖動)

20230506171253_rec_.gif

如上圖,這樣的問題,暫時沒想到什么好的辦法,我直接加上了Loading掩蓋,解決之后如下,如此效果會稍微好一點(diǎn),如果有更好的方法還望大家不吝賜教!

20230506171541_rec_.gif

平級數(shù)據(jù)拖拽

平級數(shù)據(jù)拖拽不存在上面遇到的任何問題,正常寫就好,展示一下:

20230506171828_rec_.gif

小結(jié)

到此這篇關(guān)于Vue.js結(jié)合SortableJS實(shí)現(xiàn)樹形數(shù)據(jù)拖拽的文章就介紹到這了,更多相關(guān)Vue.js樹形數(shù)據(jù)拖拽內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vuex mutitons和actions初使用詳解

    Vuex mutitons和actions初使用詳解

    這篇文章主要介紹了Vuex mutitons和actions初使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • vue 自定義指令自動獲取文本框焦點(diǎn)的方法

    vue 自定義指令自動獲取文本框焦點(diǎn)的方法

    今天小編就為大家分享一篇vue 自定義指令自動獲取文本框焦點(diǎn)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Vue3+Antd實(shí)現(xiàn)彈框顯示內(nèi)容并加入復(fù)制按鈕

    Vue3+Antd實(shí)現(xiàn)彈框顯示內(nèi)容并加入復(fù)制按鈕

    這篇文章主要介紹了Vue3+Antd實(shí)現(xiàn)彈框顯示內(nèi)容并加入復(fù)制按鈕,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-12-12
  • vue實(shí)現(xiàn)分頁加載效果

    vue實(shí)現(xiàn)分頁加載效果

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)分頁加載效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • vue?代碼壓縮優(yōu)化方式

    vue?代碼壓縮優(yōu)化方式

    這篇文章主要介紹了vue?代碼壓縮優(yōu)化方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue項目中如何調(diào)用多個不同的ip接口

    vue項目中如何調(diào)用多個不同的ip接口

    這篇文章主要介紹了vue項目中如何調(diào)用多個不同的ip接口,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • 基于Vue3+Three.js實(shí)現(xiàn)一個3D模型可視化編輯系統(tǒng)

    基于Vue3+Three.js實(shí)現(xiàn)一個3D模型可視化編輯系統(tǒng)

    這篇文章主要介紹了基于Vue3+Three.js實(shí)現(xiàn)一個3D模型可視化編輯系統(tǒng),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • 詳解Vue2.x-directive的學(xué)習(xí)筆記

    詳解Vue2.x-directive的學(xué)習(xí)筆記

    這篇文章主要介紹了詳解Vue2.x-directive的學(xué)習(xí)筆記,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • VueUse功能精簡你的dependencies

    VueUse功能精簡你的dependencies

    這篇文章主要為大家介紹了VueUse功能精簡你的dependencies實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 解決vscode進(jìn)行vue格式化,會自動補(bǔ)分號和雙引號的問題

    解決vscode進(jìn)行vue格式化,會自動補(bǔ)分號和雙引號的問題

    這篇文章主要介紹了解決vscode進(jìn)行vue格式化,會自動補(bǔ)分號和雙引號的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10

最新評論