电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

使用Vue實現一個樹組件的示例

瀏覽:91日期:2022-11-05 14:04:40

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='http://www.hdgsjgj.cn/bcjs/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: 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>

效果圖:

使用Vue實現一個樹組件的示例

以上就是使用Vue實現一個樹組件的示例的詳細內容,更多關于vue 實現樹組件的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
主站蜘蛛池模板: 台式低速离心机-脱泡离心机-菌种摇床-常州市万丰仪器制造有限公司 | 黑龙江京科脑康医院-哈尔滨精神病医院哪家好_哈尔滨精神科医院排名_黑龙江精神心理病专科医院 | 云阳人才网_云阳招聘网_云阳人才市场_云阳人事人才网_云阳人家招聘网_云阳最新招聘信息 | 生物风-销售载体,基因,质粒,ATCC细胞,ATCC菌株等,欢迎购买-百风生物 | 恒温恒湿箱(药品/保健品/食品/半导体/细菌)-兰贝石(北京)科技有限公司 | 400电话_400电话申请_888元包年_400电话办理服务中心_400VIP网 | 掺铥光纤放大器-C/L波段光纤放大器-小信号光纤放大器-合肥脉锐光电技术有限公司 | 制丸机,小型中药制丸机,全自动制丸机价格-甘肃恒跃制药设备有限公司 | 代做标书-代写标书-专业标书文件编辑-「深圳卓越创兴公司」 | 双相钢_双相不锈钢_双相钢圆钢棒_双相不锈钢报价「海新双相钢」 双能x射线骨密度检测仪_dxa骨密度仪_双能x线骨密度仪_品牌厂家【品源医疗】 | 一航网络-软件测评官网 | 利浦顿蒸汽发生器厂家-电蒸汽发生器/燃气蒸汽发生器_湖北利浦顿热能科技有限公司官网 | 天津试验仪器-电液伺服万能材料试验机,恒温恒湿标准养护箱,水泥恒应力压力试验机-天津鑫高伟业科技有限公司 | 杭州用友|用友软件|用友财务软件|用友ERP系统--杭州协友软件官网 | 北京翻译公司_同传翻译_字幕翻译_合同翻译_英语陪同翻译_影视翻译_翻译盖章-译铭信息 | 专业生物有机肥造粒机,粉状有机肥生产线,槽式翻堆机厂家-郑州华之强重工科技有限公司 | 压缩空气冷冻式干燥机_吸附式干燥机_吸干机_沪盛冷干机 | 烟雾净化器-滤筒除尘器-防爆除尘器-除尘器厂家-东莞执信环保科技有限公司 | 上海办公室设计_办公楼,写字楼装修_办公室装修公司-匠御设计 | 液氨泵,液化气泵-淄博「亚泰」燃气设备制造有限公司 | 冷镦机-多工位冷镦机-高速冷镦机厂家-温州金诺机械设备制造有限公司 | 注塑模具_塑料模具_塑胶模具_范仕达【官网】_东莞模具设计与制造加工厂家 | 标准品网_标准品信息网_【中检计量】| 南京办公用品网-办公文具用品批发-打印机耗材采购 | 洛阳装修公司-洛阳整装一站式品牌-福尚云宅装饰| 安徽成考网-安徽成人高考网| 交联度测试仪-湿漏电流测试仪-双85恒温恒湿试验箱-常州市科迈实验仪器有限公司 | 铝单板_铝窗花_铝单板厂家_氟碳包柱铝单板批发价格-佛山科阳金属 | 厂房出租_厂房出售_产业园区招商_工业地产&nbsp;-&nbsp;中工招商网 | YT保温材料_YT无机保温砂浆_外墙保温材料_南阳银通节能建材高新技术开发有限公司 | RS系列电阻器,RK_RJ启动调整电阻器,RQ_RZ电阻器-上海永上电器有限公司 | 油漆辅料厂家_阴阳脚线_艺术漆厂家_内外墙涂料施工_乳胶漆专用防霉腻子粉_轻质粉刷石膏-魔法涂涂 | 水质传感器_水质监测站_雨量监测站_水文监测站-山东水境传感科技有限公司 | 螺旋绞龙叶片,螺旋输送机厂家,山东螺旋输送机-淄博长江机械制造有限公司 | 吸污车_吸粪车_抽粪车_电动三轮吸粪车_真空吸污车_高压清洗吸污车-远大汽车制造有限公司 | 蓝米云-专注于高性价比香港/美国VPS云服务器及海外公益型免费虚拟主机 | 电动百叶窗,开窗器,电动遮阳百叶,电动开窗机生产厂家-徐州鑫友工控科技发展有限公司 | 涂层测厚仪_漆膜仪_光学透过率仪_十大创新厂家-果欧电子科技公司 | 扬尘监测_扬尘监测系统_带证扬尘监测设备 - 郑州港迪科技有限公司 | 高速龙门架厂家_监控杆_多功能灯杆_信号灯杆_锂电池太阳能路灯-鑫世源照明 | 缠绕机|缠绕膜包装机|缠绕包装机-上海晏陵智能设备有限公司 |