详解vue-element Tree树形控件填坑路

时间:2021-05-25

通过tree树形控件的default-checked-keys属性来设置默认选中的节点

html.vue

<el-form-item label="角色权限:"> <el-tree :data="data2" show-checkbox node-key="id" @check="handleNodeClick" :default-expanded-keys="[]" ref="tree" :default-checked-keys="default_select" :props="defaultProps"> </el-tree></el-form-item>

html.js

data() { return { data2: [], defaultProps: { children: 'child', label: 'name' }, menu_ids: [], // 默认选中 default_select: [], role_id: 0, } }, methods: { /** * 获取详情 */ getDetail() { let that = this; that.$http.post(that.adminApi.api_url + "/Role/show_edit", { token: that.token, role_id: that.role_id }, { emulateJSON: true }).then( function (res) { var data = res.body; if (data) { that.ruleForm.name = data.name; that.ruleForm.sort = data.sort; that.ruleForm.status = data.status.toString(); /**重点开始*/ if(typeof (data.menu_id) == 'object'){ //转数组 data.menu_id = Object.keys(data.menu_id).map(key=> data.menu_id[key]); } //赋值 data.menu_id.forEach((value)=>{ that.default_select.push(value); }); setTimeout(function () { that.default_select.forEach((value)=>{ that.$refs.tree.setChecked(value,true,false) }); },100); that.menu_ids = data.menu_id; /**重点结束*/ } }); }, /** * 属性控件 */ handleNodeClick(e, data) { console.log(data); console.log(e); this.menu_ids = data.checkedKeys }, }

总结,Tree树形控件通过后台接口获取到数组数据,还需要再次遍历,将它再遍历为数组,这样我们才可以调用,如果直接从后台获取到数组来调用的时候,我们是获取不到这个数组中的内容。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章