亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

uni-app無限級樹形組件簡單實現(xiàn)代碼

 更新時間:2025年01月13日 11:02:50   作者:洗發(fā)水很好用  
文章介紹了如何在uni-app中簡單封裝一個無限級樹形組件,該組件可以無線嵌套,展開和收縮,并獲取子節(jié)點數據,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友一起看看吧

       因為項目一些數據需要樹形展示,但是官網組件沒有?,F(xiàn)在簡單封裝一個組件在app中使用,可以無線嵌套,展開,收縮,獲取子節(jié)點數據等。

簡單效果

組件TreeData

<template>
  <view class="tree">
    <template v-for="(node, index) in treeData">
      <view>
        <span @click="toggleNode($event, node)">
          <uni-icons
            v-if="node.children && node.children.length > 0"
            :type="node.expanded ? 'arrowdown' : 'arrowright'"
            size="14"
          ></uni-icons>
          {{ node.label }}
        </span>
        <span
          @click.stop="deleteNode($event, node)"
          class="action-button delete-button"
          >刪除</span
        >
        <span
          @click.stop="editNode($event, node)"
          class="action-button edit-button"
          >編輯</span
        >
        <view v-if="node.expanded" class="children">
          <Tree
            :treeData="node.children"
            @edit-node="(childNode) => $emit('edit-node', childNode)"
            @delete-node="(childNode) => $emit('delete-node', childNode)"
          />
        </view>
      </view>
    </template>
  </view>
</template>
<script>
export default {
  name: "Tree",
  props: {
    treeData: {
      type: Array,
      default: () => [],
    },
    expandAll: {
      type: Boolean,
      default: true,
    },
  },
  data() {
    return {
      init: false,
    };
  },
  watch: {
    treeData: {
      immediate: true,
      handler(newData) {
        if (!this.init) {
          this.initializeTreeData(newData, this.expandAll);
          this.init = true;
        }
      },
    },
  },
  methods: {
    initializeTreeData(nodes, expanded) {
      nodes.forEach((node) => {
        this.$set(node, "expanded", expanded); // 使用 $set 確保響應式
        if (node.children && node.children.length > 0) {
          this.initializeTreeData(node.children, expanded); // 遞歸處理子節(jié)點
        }
      });
    },
    toggleNode(event, node) {
      event.stopPropagation(); // 阻止事件冒泡
      node.expanded = !node.expanded; // 切換節(jié)點展開狀態(tài)
    },
    editNode(event, node) {
      event.stopPropagation();
      this.$emit("edit-node", node); // 觸發(fā)父組件的 edit-node 事件,并傳遞當前節(jié)點
    },
    deleteNode(event, node) {
      event.stopPropagation();
      this.$emit("delete-node", node); // 觸發(fā)父組件的 delete-node 事件,并傳遞當前節(jié)點
    },
  },
};
</script>
  <style scoped>
.tree {
  padding-left: 15px;
}
.children {
  padding-left: 15px;
}
.tree-node {
  display: flex;
  align-items: center;
}
.action-button {
  cursor: pointer;
  margin-left: 10px;
  color: #409eff;
}
.edit-button {
  float: right;
}
.delete-button {
  float: right;
}
</style>

在頁面中使用...

<template>
  <view class="page">
    <Tree
      :treeData="treeData"
      :expandAll="expandAll"
      @edit-node="handleEditNode"
      @delete-node="handleDeleteNode"
    />
  </view>
</template>
<script>
import Tree from "@/components/TreeData";
export default {
  components: {
    Tree,
  },
  data() {
    return {
      treeData: [
        {
          label: "根節(jié)點 1",
          children: [
            {
              label: "子節(jié)點 1-1",
              children: [
                {
                  label: "子節(jié)點 1-1-1",
                  children: [],
                },
                {
                  label: "子節(jié)點 1-1-2",
                  children: [],
                },
              ],
            },
            {
              label: "子節(jié)點 1-2",
              children: [],
            },
          ],
        },
        {
          label: "根節(jié)點 2",
          children: [
            {
              label: "子節(jié)點 2-1",
              children: [],
            },
          ],
        },
      ],
      expandAll: true, // 控制是否全部展開
    };
  },
  methods: {
    handleEditNode(node) {
      console.log("編輯節(jié)點", node);
      // 處理編輯節(jié)點的邏輯
    },
    handleDeleteNode(node) {
      console.log("刪除節(jié)點", node);
      // 處理刪除節(jié)點的邏輯
    },
  },
};
</script>
<style scoped>
page {
  background-color: #f5f6f8;
}
.page {
  padding: 20px;
}
</style>

到此這篇關于uni-app無限級樹形組件簡單實現(xiàn)的文章就介紹到這了,更多相關uni-app無限級樹形組件內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue 處理跨域問題及解決方法小結

    vue 處理跨域問題及解決方法小結

    跨域問題的出現(xiàn)是因為瀏覽器的同源策略問題,如果沒有同源策略我們的瀏覽器將會十分的不安全,隨時都可能受到攻擊,今天小編通過本文給大家介紹下vue 處理跨域問題,感興趣的朋友一起看看吧
    2021-09-09
  • vueJS簡單的點擊顯示與隱藏的效果【實現(xiàn)代碼】

    vueJS簡單的點擊顯示與隱藏的效果【實現(xiàn)代碼】

    下面小編就為大家?guī)硪黄獀ueJS簡單的點擊顯示與隱藏的效果【實現(xiàn)代碼】。小編覺得挺不錯的,現(xiàn)在分享給大家,一起跟隨小編過來看看吧
    2016-05-05
  • 基于Vue2x實現(xiàn)響應式自適應輪播組件插件VueSliderShow功能

    基于Vue2x實現(xiàn)響應式自適應輪播組件插件VueSliderShow功能

    本文講述的是從開發(fā)一款基于Vue2x的響應式自適應輪播組件插件的一個全過程,包含發(fā)布到npm,構建自己的npm包,供下載安裝使用的技巧,非常不錯,具有一定的參考借鑒價值,感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-05-05
  • vue項目打包后網頁的title亂碼解決方案

    vue項目打包后網頁的title亂碼解決方案

    這篇文章主要介紹了vue項目打包后網頁的title亂碼解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 圖文詳解keep-alive如何清除緩存

    圖文詳解keep-alive如何清除緩存

    vue項目中常常會用到keepalive來作緩存,在應付基本要求上能夠說很是方便,可是遇到同一個頁面,根據條件不一樣,分別緩存或者不緩存,就有些麻煩了,這篇文章主要給大家介紹了關于keep-alive如何清除緩存的相關資料,需要的朋友可以參考下
    2021-08-08
  • Vue項目打包壓縮的實現(xiàn)(讓頁面更快響應)

    Vue項目打包壓縮的實現(xiàn)(讓頁面更快響應)

    這篇文章主要介紹了Vue項目打包壓縮的實現(xiàn)(讓頁面更快響應),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • 詳解如何實現(xiàn)Element樹形控件Tree在懶加載模式下的動態(tài)更新

    詳解如何實現(xiàn)Element樹形控件Tree在懶加載模式下的動態(tài)更新

    這篇文章主要介紹了詳解如何實現(xiàn)Element樹形控件Tree在懶加載模式下的動態(tài)更新,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-04-04
  • 利用Vue3實現(xiàn)一個可以用js調用的組件

    利用Vue3實現(xiàn)一個可以用js調用的組件

    最近遇到個功能要求,想要在全局中調用組件,而且要在某些js文件內調用,所以這篇文章主要給大家介紹了關于如何利用Vue3實現(xiàn)一個可以用js調用的組件的相關資料,需要的朋友可以參考下
    2021-08-08
  • VueX瀏覽器刷新如何實現(xiàn)保存數據

    VueX瀏覽器刷新如何實現(xiàn)保存數據

    這篇文章主要介紹了VueX瀏覽器刷新如何實現(xiàn)保存數據,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue使用路由守衛(wèi)實現(xiàn)菜單的權限設置

    vue使用路由守衛(wèi)實現(xiàn)菜單的權限設置

    我們使?vue-element-admin前端框架開發(fā)后臺管理系統(tǒng)時,?般都會涉及到菜單的權限控制問題,下面這篇文章主要給大家介紹了關于vue使用路由守衛(wèi)實現(xiàn)菜單的權限設置的相關資料,需要的朋友可以參考下
    2023-06-06

最新評論