使用Vue實現一個樹組件

来源:https://www.cnblogs.com/s0611163/archive/2020/01/15/12197576.html
-Advertisement-
Play Games

HTML代碼: <!DOCTYPE html> <html> <head> <title>Vue Demo</title> <meta charset="utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta nam ...


HTML代碼:

<!DOCTYPE html>
<html>
<head>
    <title>Vue Demo</title>

    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">

    <style type="text/css">
        /* span樣式 */
        .treeviewitem-span {
            font-size: 14px;
        }

        /* 箭頭樣式 */
        .treeviewitem-arrow-icon {
            margin-top: 3px;
            margin-left: 3px;
            margin-right: 3px;
            float: left;
            width: 0;
            height: 0;
            border-top-width: 6px;
            border-right-width: 0px;
            border-bottom-width: 6px;
            border-left-width: 6px;
            border-style: solid;
            border-color: transparent transparent transparent #666666;
            transform: rotate(0deg);
        }

        /* 90度旋轉箭頭樣式 */
        .treeviewitem-arrow-icon90 {
            margin-top: 3px;
            margin-left: 3px;
            margin-right: 3px;
            float: left;
            width: 0;
            height: 0;
            border-top-width: 6px;
            border-right-width: 0px;
            border-bottom-width: 6px;
            border-left-width: 6px;
            border-style: solid;
            border-color: transparent transparent transparent #666666;
            transform: rotate(90deg);
        }

        /* 模板隱藏 */
        template {
            display: none;
        }
    </style>

    <script type="text/javascript" src="vue.js"></script>
    <script type="text/javascript">

    </script>
</head>
<body>
    <!-- treeviewitem模板 -->
    <template id="treeviewitem">
        <div>
            <div style="background-color:transparent; cursor:default; height:25px;"><div v-on:click="expand" style="width:16px; height:16px; float:left; background-color:transparent;"><span v-bind:class="[self.expand ? 'treeviewitem-arrow-icon90':'treeviewitem-arrow-icon']" v-if="isLeaf"></span></div><input type="checkbox" v-on:click="checkboxClick" v-model="self.selected" /><span v-on:click="itemClick" class="treeviewitem-span">{{ self.name }}</span></div>
            <div v-if="self.expand" v-for="item in items" style="margin-left:20px;">
                <treeviewitem v-bind:items="item.items" v-bind:self="item"></treeviewitem>
            </div>
        </div>
    </template>

    <!-- treeview模板 -->
    <template id="treeview">
        <div>
            <div v-for="item in items">
                <treeviewitem v-bind:items="item.items" v-bind:self="item"></treeviewitem>
            </div>
        </div>
    </template>

    <div id="app">
        <!-- 使用treeview組件 -->
        <treeview v-bind:items="items"></treeview>
        <br />
        <button onclick="showSelectedResult()">勾選結果</button>
    </div>

    <script type="text/javascript">
        //定義treeviewitem組件
        Vue.component('treeviewitem', {
            props: ['items', 'self'],
            template: '#treeviewitem',
            methods: {
                itemClick: function (d) {
                    alert("您單擊了節點:" + this.self.name);
                },
                checkboxClick: function (e) {
                    var checkChild;
                    checkChild = function (items, checked) {
                        for (var i = 0; i < items.length; i++) {
                            var item = items[i];
                            item.selected = checked;
                            if (item.items) {
                                checkChild(item.items, checked)
                            }
                        }
                    };

                    if (e.target.checked) {
                        checkChild(this.items, true);
                    } else {
                        checkChild(this.items, false);
                    }
                },
                expand: function (e) {
                    if (this.self.expand) {
                        this.self.expand = false;
                    } else {
                        this.self.expand = true;
                    }
                }
            },
            computed: {
                isLeaf: function () {
                    if (this.items && this.items.length > 0) {
                        return true;
                    }
                    return false;
                }
            }
        });

        //定義treeview組件
        Vue.component('treeview', {
            props: ['items'],
            template: '#treeview'
        });

        //定義vm
        var vm = new Vue({
            el: '#app',
            methods: {
                /**
                 * @description 獲取勾選結果
                 */
                getSelected: function (items) {
                    if (!items) items = this.items;

                    var result = [];
                    for (var i = 0; i < items.length; i++) {
                        var item = items[i];
                        if (item.selected) {
                            result.push(item.name);
                        }
                        if (item.items) {
                            var childSelected = this.getSelected(item.items);
                            for (var k = 0; k < childSelected.length; k++) {
                                result.push(childSelected[k]);
                            }
                        }
                    }
                    return result;
                }
            },
            data: {
                items: [
                    {
                        name: '條目1',
                        expand: true,
                        selected: false,
                        items: [
                            {
                                name: '條目11',
                                expand: true,
                                selected: false,
                                items: [
                                    {
                                        name: '條目111',
                                        expand: true,
                                        selected: true,
                                    }
                                ]
                            },
                            {
                                name: '條目12',
                                expand: false,
                                selected: false,
                                items: [
                                    {
                                        name: '條目121',
                                        expand: true,
                                        selected: false,
                                    },
                                    {
                                        name: '條目122',
                                        expand: true,
                                        selected: false,
                                        items: [
                                            {
                                                name: '條目1221',
                                                expand: true,
                                                selected: false
                                            },
                                            {
                                                name: '條目1222',
                                                expand: true,
                                                selected: false
                                            }
                                        ]
                                    }
                                ]
                            },
                            {
                                name: '條目13',
                                expand: true,
                                selected: false
                            }
                        ]
                    },
                    {
                        name: '條目2',
                        expand: true,
                        selected: false
                    },
                    {
                        name: '條目3',
                        expand: true,
                        selected: false,
                        items: [
                            {
                                name: "條目31",
                                expand: true,
                                selected: false
                            }
                        ]
                    }
                ]
            }
        })

        //顯示勾選結果
        function showSelectedResult() {
            var selected = vm.getSelected();
            alert("您勾選了:" + selected.join(', '));
        }
    </script>
</body>
</html>
View Code

效果圖:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近在自學看 資料庫系統概論 這本書,總結一下遇到的問題。 1.廣義笛卡爾積(Extende cartesian product): 屬於 關係代數 裡面的 傳統的集合運算。其他的為union,except,intersection. 詳情不提了,舉個例子就是: create table R(A c ...
  • 什麼是移動App開發【重點】 1. 蘋果上的軟體是如何開發出來的:使用IOS平臺的開發工具和開發語言進行設計開發的!蘋果上的開發語言:OC、Swift 2. 安卓平臺上的軟體又是如何開發出來的:使用Java這麼語言,結合一些Android控制項,就可以開發安卓上的手機軟體; 3. 蘋果和安卓平臺上共有 ...
  • Android項目用Gradle構建, 其腳本語言之前是Groovy, 目前也提供了Kotlin的支持, 所以可以遷移到Kotlin. 官方的遷移文檔說明的是更通用的步驟. 本文通過一個具體的Android項目來舉例如何遷移, 文後附有sample. ...
  • Plugin(插件) 是 webpack 生態的的一個關鍵部分。它為社區提供了一種強大的方法來擴展 webpack 和開發 webpack 的編譯過程。這篇文章將嘗試探索 webpack plugin,揭秘它的工作原理,以及如何開發一個 plugin。 ...
  • jquery: 簡單、粗暴 jq和js的關係 js是什麼? js是一門編程語言 jq僅僅是基於js的一個庫,jq可理解為就是開發js的一個工具。 概念 1. 為什麼要學jquery ? 簡單,粗暴 沒有相容性問題 2. 什麼是jquery?js庫,說白了就是js文件,裡面有一大堆的方法 3. 使用j ...
  • 淘寶精品案例 <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style type="text/css"> * { margin: 0; padding: 0; font-size: 12 ...
  • 手風琴案例 <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style type="text/css"> * { padding: 0; margin: 0; } ul { list-st ...
  • 突出展示案例 <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style type="text/css"> * { margin: 0; padding: 0; } ul { list-s ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...