“This article has participated in the good article call order activity, click to see: back end, big front end double track submission, 20,000 yuan prize pool for you to challenge!”
[TOC]
Tree control in the front end of the development is essential, for the display of data now most sites take Tree display. Because big data is not user-friendly to display in full. Today we are writing a Tree plugin by hand.
Controls provided by iView
- Iview is very mature, if the control I wrote is better than the control provided by iView, it must be selected iView, hand-written control is just to better understand the communication between vUE parent and child components. Please do not compare my control to iView or other third parties. Below we first look at iView Tree control how to use
<template>
<Tree :data="data2" show-checkbox></Tree>
</template>
<script>
export default {
data () {
return {
data2: [
{
title: 'parent 1',
expand: true,
children: [
{
title: 'parent 1-1',
expand: true,
children: [
{
title: 'leaf 1-1-1'
},
{
title: 'leaf 1-1-2'
}
]
},
{
title: 'parent 1-2',
expand: true,
children: [
{
title: 'leaf 1-2-1'
},
{
title: 'leaf 1-2-1'
}
]
}
]
}
]
}
}
}
</script>
Copy the code
- The effect of the above code formation is as follows
- When using the Tree control, you can also use the following Tree in the Template (depending on your needs).
- Then there is some event capture for the control
- Some Settings for child nodes
- For iView Tree summary is a word: in place! . Here xiaobian also recommends that you use iView to develop. This framework is a boon for back-end programmers. Because we don’t need to know too much about the front end just to be able to meet 80% of the needs.
The hand control
Again, let’s see how it’s used first. It’s actually the same as iView. Just use the template that we encapsulate. The following is to make a department tree. Under the department hangs the personnel function.
<zxhtree
v-if="userChange"
class="item"
treekey="deptId"
treename="deptName"
treechildren="children"
:model="deptData"
:ids="sysUserRole.deptIds"
:names="sysUserRole.deptNames"
@keyname="selectedUserObj"
>
</zxhtree>
Copy the code
Js is used to fill in data such as deptData, sysUserRole, etc. We’ll wait to see what these properties mean. Let’s start with the renderings.
Where did we register our zxhTree control? We pulled it out of component.js. Vue.component(‘zxhtree’, {}); Select * from ‘zxhtree’ where template: ‘#tree-template’ The template for tree-template is written in component.html
<script type="text/x-template" id="tree-template">
<div>
<tree-item
class="item"
:treekey="treekey"
v-for="(model, index) in model"
:treename="treename"
:treechildren="treechildren"
:model="model"
:ids="ids"
:names="names"
@keyname="selectedObj"
@data="synchdata"
>
</tree-item>
</div>
</script>
Copy the code
The tree-item control used in the tree-template is the true Tree control. The purpose here is to wrap the tree, so I have a layer of template. The template code for tree-item is
<script type="text/x-template" id="item-template">
<ul class="ztree">
<li class="level0" @blur="blur" @focus="focus" tabindex="0" hidefocus="true" treenode="">
<input type="checkbox" :disabled="model.disabled" :ref="model[treename]" :checked="checkStatus" @click="selectedObj"/>
<span title="" @click="toggle" :class="openStatus" treenode_switch=""></span>
<a :class="selectClass" treenode_a="" onclick="" target="_blank" style="" :title="model[treename]">
<span title="" treenode_ico="" class="button ico_open" style=""></span>
<span @dblclick="toggle" class="node_name">{{model[treename]}}</span>
</a>
<tree-item
class="item"
v-show="open"
v-for="(model, index) in model[treechildren]"
:key="index"
:model="model"
:treekey="treekey"
:treename="treename"
:vistreekey="vistreekey"
:vistreename="vistreename"
:treechildren="treechildren"
ref="child"
@keyname="keyname"
>
</tree-item>
</li>
</ul>
</script>
Copy the code
And you can see clearly that we’re using recursion to show the tree. Because of the tree structure you can’t determine the hierarchy. So there’s a display tree-item for child nodes.
attribute | meaning | The sample |
---|---|---|
treekey | The interior is displayed as a tree | deptId |
vistreekey | The tree displays the key | deptId |
ids | The data displayed by default | There is no |
names | The data displayed by default | There is no |
treename | The interior really shows the data | deptName |
vistreename | The tree displays the data | deptName |
treechildren | The child node data of the current tree | There is no |
model | The current tree data | There is no |
(M)keyname | Used to accept the returned data | There is no |
Handwritten control extension
Control accepts data processing logic
If (this.model[this.treeKey]==undefined){this.treeKey = this.vistreeKey; } if(this.model[this.treename]==undefined){ this.treename=this.vistreename; } if (this.model.disabled == true) { this.model.disabled = 'disabled'; } console.log(' Is the component registered? '); if ((','+this.ids+',').indexOf(','+this.model[this.treekey]+',') == -1) { this.checkStatus = false; this.model.checkStatus=this.checkStatus; } else { this.checkStatus=true; this.model.checkStatus=this.checkStatus; this.treekeys[this.model[this.treekey]]= this.checkStatus; this.treenames[this.model[this.treename]]= this.checkStatus; this.opt.key=this.treekeys; this.opt['name']=this.treenames; } if(this.ids! =''){ var idarr = this.ids; for(var index in idarr){ this.treekeys[idarr[index]]=true; } if (this.names.indexOf(",") == -1&&this.names! ='') { this.treenames[this.names]=true; }else{ var namearr = this.names.split(","); for(var index in namearr){ this.treenames[namearr[index]]=true; }}}Copy the code
Render default data
var newOpt ={'key':{},'name':{}}; newOpt.key = Object.assign(this.opt.key, opt.key); newOpt.name = Object.assign(this.opt.name, opt.name); var flag=false; for(var index in this.model[this.treechildren]){ if(newOpt.key[this.model[this.treechildren][index][this.treekey]]! =true){ flag=true; } } if(! flag){ newOpt.key[this.model[this.treekey]]=true; newOpt.name[this.model[this.treename]]=true; this.checkStatus=true; this.model.checkStatus=true; } for(var key in newOpt){ this.filterRealCheck(newOpt[key]); } this.opt=newOpt; this.$emit('keyname', newOpt);Copy the code
Select node data processing
if(selected instanceof MouseEvent){ this.checkStatus=! this.checkStatus; }else{ this.checkStatus=selected; } this.model.checkStatus=this.checkStatus; if (this.model.expected ! = true) { this.treekeys[this.model[this.treekey]]= this.checkStatus; this.treenames[this.model[this.treename]]= this.checkStatus; this.opt.key=this.treekeys; this.opt['name']=this.treenames; } for(var index in this.$refs.child){ this.$refs.child[index].selectedObj(this.checkStatus); } this.$emit('keyname', this.opt);Copy the code
Summary of Handwritten Controls
Because the author is focused on the back end, so the front-end knowledge is not very good, this component is also very messy. This component was written temporarily earlier. There is no systematic combing, the above logic is also very messy. Readers need to choose the following to join the team (#addMe) contact me need source code can be concerned about the following public number sent click into the group after consultation.