成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

Vue Element前端應(yīng)用開發(fā)之樹列表組件

瀏覽:4日期:2022-09-29 17:50:24
目錄1、常規(guī)樹列表控件的使用2、下拉框樹列表的處理1、常規(guī)樹列表控件的使用

眾所周知,一般界面很多情況涉及到樹列表的處理,如類型展示,如果是一層的,可以用下拉列表代替,如果是多個層級的,采用樹控件展示會更加直觀。

在Element里面也有一個el-tree的控件,如下所示,這里主要對它的各種屬性和方法進(jìn)行介紹。

Vue Element前端應(yīng)用開發(fā)之樹列表組件

簡單的代碼如下所示

<el-tree :data='data' @node-click='handleNodeClick'></el-tree>

主要在script部分里面指定它的data數(shù)據(jù),以及單擊節(jié)點(diǎn)的事件處理,結(jié)合卡片控件的展示,我們可以把樹放在其中進(jìn)行展示

Vue Element前端應(yīng)用開發(fā)之樹列表組件

界面代碼如下所示,通過default-expand-all 可以設(shè)置全部展開,icon-class 指定節(jié)點(diǎn)圖標(biāo)(也可以默認(rèn)不指定)

<el-card class='box-card'> <div slot='header' class='clearfix'> <span>樹列表</span> <el-button type='text'>操作按鈕</el-button> </div> <div> <el-tree :data='treedata' node-key='id' default-expand-all icon- highlight-current @node-click='handleNodeClick' > <span slot-scope='{ node, data }' class='custom-tree-node'><span> <i : /> {{ node.label }}   </span> </span> </el-tree> </div></el-card>

其中界面里面,我們通過class='custom-tree-node',來指定樹列表的展現(xiàn)內(nèi)容,可以加入圖標(biāo)等信息

而在script里面,定義了一個treedata的屬性

// 初始化樹列表 treedata: [{ label: ’一級 1’, id: ’1’, children: [{ id: ’1-1’, label: ’二級 1-1’, children: [{ label: ’三級 1-1-1’, id: ’1-1-1’ }, { label: ’三級 1-1-2’, id: ’1-1-2’ }, { label: ’三級 1-1-3’, id: ’1-1-3’ }] }]} ]

如果設(shè)置有選擇框,得到界面如下所示。

Vue Element前端應(yīng)用開發(fā)之樹列表組件

主要設(shè)置show-checkbox 和@check-change='handleCheckChange' 即可。

界面代碼如下所示

<el-tree :data='treedata' node-key='id' default-expand-all highlight-current show-checkbox :default-checked-keys='[’1-1-1’]' @node-click='handleNodeClick' @check-change='handleCheckChange'> <span slot-scope='{ node, data }' class='custom-tree-node'> <span> <i : /> {{ node.label }}    </span> </span></el-tree>

而對于樹列表,可以進(jìn)行一個過濾處理操作,如下界面所示。

Vue Element前端應(yīng)用開發(fā)之樹列表組件

在內(nèi)容區(qū)增加一個input的文本框進(jìn)行過濾處理,并綁定對應(yīng)的屬性變量

<el-input v-model='filterText' placeholder='輸入關(guān)鍵字進(jìn)行過濾' clearable prefix-icon='el-icon-search'/>

樹列表控件需要增加過濾函數(shù)綁定:filter-node-method='filterNode',如下代碼所示。

<el-tree ref='tree':data='treedata' node-key='id' default-expand-all highlight-current show-checkbox :filter-node-method='filterNode' @check-change='handleCheckChange' @node-click='handleNodeClick'> <span slot-scope='{ node, data }' class='custom-tree-node'> <span> <i : /> {{ node.label }}    </span> </span></el-tree>

script的處理代碼如下所示,需要watch過濾的綁定值,變化就進(jìn)行過濾處理。

Vue Element前端應(yīng)用開發(fā)之樹列表組件

為了在列表結(jié)合中進(jìn)行快速的過濾,我們可以在上次介紹的列表界面里面增加一個樹列表的快速查詢處理。如下界面所示。

Vue Element前端應(yīng)用開發(fā)之樹列表組件

這里列表里面增加了一個第三方組件splitpanes,用來劃分區(qū)塊展示,而且可以拖動,非常不錯,地址是:

https://github.com/antoniandre/splitpanes

這個組件的Demo展示地址如下所示:https://antoniandre.github.io/splitpanes

效果大概如下所示

Vue Element前端應(yīng)用開發(fā)之樹列表組件

npm安裝如下所示

npm i --S splitpanes

安裝成功后,然后在vue文件的script部分里面引入即可

import { Splitpanes, Pane } from ’splitpanes’import ’splitpanes/dist/splitpanes.css’

它的使用代碼也很簡單

<splitpanes style='height: 400px'> <pane min-size='20'>1</pane> <pane> <splitpanes horizontal> <pane>2</pane> <pane>3</pane> <pane>4<pane> </splitpanes> </pane> <pane>5</pane></splitpanes>

我的列表界面使用了兩個Panel即可實現(xiàn)左側(cè)樹的展示,和右側(cè)常規(guī)列表查詢的處理。

Vue Element前端應(yīng)用開發(fā)之樹列表組件

2、下拉框樹列表的處理

除了常規(guī)的樹列表展示內(nèi)容外,我們也需要一個在下拉列表中展示樹內(nèi)容的界面組件。

這里又得引入一個第三方的界面組件,因此Element的Select組件不支持樹列表。

GitHub地址:https://github.com/riophae/vue-treeselect

官網(wǎng)地址:https://vue-treeselect.js.org/

NPM安裝:

npm install --save @riophae/vue-treeselect

界面代碼如下所示。

<template> <div id='app'> <treeselect v-model='value' :multiple='true' :options='options' /> </div></template>

這里的value就是選中的集合,options則是樹列表的節(jié)點(diǎn)數(shù)據(jù)。

<script> // import the component import Treeselect from ’@riophae/vue-treeselect’ // import the styles import ’@riophae/vue-treeselect/dist/vue-treeselect.css’ export default { // register the component components: { Treeselect }, data() { return {// define the default valuevalue: null,// define optionsoptions: [ { id: ’a’, label: ’a’, children: [ { id: ’aa’, label: ’aa’, }, { id: ’ab’, label: ’ab’, } ],}, { id: ’b’, label: ’b’,}, { id: ’c’, label: ’c’,} ], } }, }</script>

我的測試界面代碼如下所示

<div style='height:180px'> <!--v-model 綁定選中的集合options 樹節(jié)點(diǎn)數(shù)據(jù) defaultExpandLevel 展開層次,Infinity為所有 flat 為子節(jié)點(diǎn)不影響父節(jié)點(diǎn),不關(guān)聯(lián) --> <treeselect v-model='value' :options='treedata' :multiple='true' :flat='true' :default-expand-level='Infinity' :open-on-click='true' :open-on-focus='true' clearable :max- /> </div>

<script>// import vue-treeselect componentimport Treeselect from ’@riophae/vue-treeselect’// import the stylesimport ’@riophae/vue-treeselect/dist/vue-treeselect.css’export default { name: ’Tree’, components: { Treeselect }, data() { return { // 過濾條件 filterText: ’’, // 初始化樹列表 treedata: [{ label: ’一級 1’, id: ’1’, children: [{ id: ’1-1’, label: ’二級 1-1’, children: [{ label: ’三級 1-1-1’, id: ’1-1-1’ }, { label: ’三級 1-1-2’, id: ’1-1-2’ }, { label: ’三級 1-1-3’, id: ’1-1-3’ }] }]} ], value: [’1-1-2’] } },................}</script>

來一張幾個樹列表一起的對比展示界面。

Vue Element前端應(yīng)用開發(fā)之樹列表組件

以上就是普通樹列表和下拉列表樹展示的界面效果,往往我們一些特殊的界面處理,就需要多利用一些封裝良好的第三方界面組件實現(xiàn),可以豐富我們的界面展示效果

以上就是Vue Element前端應(yīng)用開發(fā)之樹列表組件的詳細(xì)內(nèi)容,更多關(guān)于Vue Element樹列表組件的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
欧洲亚洲国产日韩| 另类小说综合欧美亚洲| 亚洲国产精品一区二区www在线 | 国产一区二区三区国产| 国产精品普通话对白| 国产精品久久久久7777按摩| 成人av电影在线网| 欧美巨大另类极品videosbest | 国产精品久久久一区二区三区| 欧美极品美女视频| 成人激情文学综合网| 欧美色涩在线第一页| 亚洲1区2区3区4区| 国产欧美日韩亚洲一区二区三区| 国产精品狼人久久影院观看方式| 久久综合九色综合网站| 午夜精品成人在线视频| 鲁大师影院一区二区三区| 一区二区三区精品视频| 亚洲精品日韩久久| 一区二区视频在线看| 亚洲视频高清| 亚洲欧洲日韩女同| 一本色道久久综合一区| 亚洲男人天堂av网| 亚洲免费精品| 亚洲激情一二三区| 亚洲精品在线视频观看| 亚洲精品你懂的| 亚洲区一区二| 亚洲精品欧美在线| 久久精品盗摄| 日韩不卡免费视频| 欧美唯美清纯偷拍| 韩国v欧美v日本v亚洲v| 91精品国产乱| 成人一区二区视频| 久久久精品综合| 欧美日韩精品免费观看 | 毛片不卡一区二区| 91精品国产免费久久综合| av一区二区不卡| 中文字幕一区二区三区四区不卡 | 亚欧色一区w666天堂| 亚洲制服av| 美女视频网站黄色亚洲| 欧美一二三区在线观看| 9人人澡人人爽人人精品| 国产欧美精品一区二区三区四区| 欧美三级特黄| 一区二区视频免费在线观看| 色噜噜狠狠色综合中国| 国产综合色在线视频区| 精品国产91久久久久久久妲己| 午夜精品网站| 亚洲激情综合网| 在线视频一区二区三| 国产成人免费网站| 国产午夜精品一区二区三区视频| 欧美一区二区视频在线| 亚洲女厕所小便bbb| 欧洲国内综合视频| 成人免费福利片| 亚洲欧洲另类国产综合| 色国产综合视频| av在线不卡观看免费观看| 17c精品麻豆一区二区免费| 蜜桃av久久久亚洲精品| 国产精品88888| 国产精品美日韩| 色女孩综合影院| 岛国一区二区三区| 亚洲精品国产一区二区三区四区在线 | 不卡av在线网| 日韩一区欧美一区| 欧美日韩中文字幕一区| 91丝袜国产在线播放| 亚洲国产综合视频在线观看| 欧美日韩久久久| 黑人一区二区三区四区五区| 免费xxxx性欧美18vr| 国产欧美一区二区精品忘忧草| 久久精品免费| 成人涩涩免费视频| 一区二区三区波多野结衣在线观看 | 成人免费视频app| 亚洲天堂成人在线观看| 欧美视频一区二| 91美女在线视频| 亚洲成人黄色小说| 精品国产乱子伦一区| 亚洲一区二区成人| gogo大胆日本视频一区| 亚洲第一电影网| 2020日本不卡一区二区视频| 欧美亚洲专区| 97精品电影院| 免费观看在线色综合| 综合久久一区二区三区| 欧美一级艳片视频免费观看| 91久久极品少妇xxxxⅹ软件| 成人免费福利片| 日韩电影在线免费看| 国产精品欧美久久久久无广告| 欧美三级电影一区| 一区在线播放| 成人久久18免费网站麻豆| 天堂蜜桃一区二区三区| 国产精品久久夜| 制服丝袜日韩国产| 免费在线日韩av| 91农村精品一区二区在线| 美日韩一区二区三区| 中文字幕一区二区三区视频| 日韩欧美国产一区二区三区| 亚洲综合国产| 欧美精品观看| 成人不卡免费av| 久久99蜜桃精品| 亚洲成人综合网站| 最近日韩中文字幕| 26uuu国产一区二区三区 | 国产精品久久久久久久久搜平片| 欧美电影一区二区| 亚洲专区在线| 国产一区自拍视频| 成人国产精品免费| 国产在线日韩欧美| 天天综合色天天综合色h| 国产无遮挡一区二区三区毛片日本| 色噜噜偷拍精品综合在线| 亚洲黄色一区| 欧美1区视频| 成人亚洲一区二区一| 青青草原综合久久大伊人精品| 亚洲欧美一区二区三区极速播放| 精品久久久久一区二区国产| 欧美中文字幕亚洲一区二区va在线 | 97久久精品人人爽人人爽蜜臀| 日韩高清欧美激情| 亚洲色图丝袜美腿| 久久噜噜亚洲综合| 欧美一区二区观看视频| 在线免费亚洲电影| 久久精品国产清高在天天线 | 欧美日韩三级一区| 亚欧美中日韩视频| 亚洲欧洲一区二区天堂久久| 91视频com| 成人av午夜影院| 国产精品99久久久久| 蜜桃久久av一区| 爽爽淫人综合网网站| 亚洲激情欧美激情| 亚洲青青青在线视频| 自拍偷拍亚洲综合| 中文字幕中文字幕一区二区| 国产日产欧产精品推荐色| 精品欧美乱码久久久久久| 91精品一区二区三区在线观看| 91官网在线免费观看| 午夜亚洲伦理| 91久久久久| 极品尤物久久久av免费看| 欧美黄在线观看| 欧美一区二区三区久久精品| 不卡免费追剧大全电视剧网站| 国产精品一区二区免费不卡 | 欧美日韩亚州综合| 久久久久久一区| 中文日韩欧美| 好吊一区二区三区| 影音先锋一区| 最新成人av网站| 亚洲少妇一区| 国产精品五区| 国产精品有限公司| 亚洲专区欧美专区| 米奇777在线欧美播放| 久久裸体视频| 一本高清dvd不卡在线观看 | 欧美韩日一区二区三区四区| 久久精品夜夜夜夜久久| 欧美sm极限捆绑bd| 日韩欧美一区在线观看| 欧美一级免费观看| 欧美成人a∨高清免费观看| 日韩一级片在线观看| 欧美成人vps| 久久综合狠狠综合久久激情| 久久久不卡网国产精品一区| 欧美激情资源网| 国产精品黄色在线观看| 亚洲欧美另类图片小说| 亚洲午夜视频在线| 日本大胆欧美人术艺术动态| 久久91精品国产91久久小草| 精品影视av免费| 国产精品99久| 波多野结衣视频一区|