• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

详解Vue.js iview实现树形权限表(可扩展表)

vue 搞代码 4年前 (2022-01-08) 58次浏览 已收录 0个评论

这篇文章主要介绍了详解Vue.js iview实现树形权限表(可扩展表),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

问题:

需要一个可折叠的权限管理系统,用表格展示。

主要用的iView组件库,有Table(表格),Tree(树形控件),Collapse(折叠面板)看起来比较符合意思

深入查看Table相关范例,发现有个 通过给 columns 数据设置一项,指定 type: 'expand',即可开启扩展功能  可以考虑

但也只是展开详细内容,如需树形结构,则需要render自定义去渲染,挺麻烦的。再去看看element UI,也没有什么比较好的选择。

过程:

第一步,先构建根节点的数据表,后台返回JSON数据解析(www.json.cn)基本如下

前面2个object和第三个结构基本类似,将数据注入authlist,匹配listcolumns展示

展示结果如下:

        

第二步,添加Columns的扩展expand功能,在listcolumns里添加

 listcolumns: [{ title: '序号', key: '_index', className: 'index_css', render: (h, params) = >{ return h('div', [h('span', { style: { display: 'inline-block', width: '100%', overflow: 'hidden', textOverflow: 'ellipsis', whiteSpace: 'nowrap', textAlign: 'center' } }, params.row._index)]); } }, { //添加的expand type: 'expand', width: 20, render: (h, params) = >{ return h(expandRow, { style: { padding: 0 }, props: { row: params.row } }) } }, { title: '权限名称', key: 'Title', className: 'Title_css', ellipsis: true, render: (h, params) = >{ return h('div', [h('span', { style: { display: 'inline-block', width: '100%', overflow: 'hidden', textOverflow: 'ellipsis', whiteSpace: 'nowrap' } }, params.row.Title)]); } },

展示

第三步:authtable_expand.vue子组件,基本和父组件的Table一致

  <table style="max-height: 522px"> </table> import expandRow from '../components/authtable_expand.vue'; export default { props: ['row'], data() { return { loading: false, listcolumns: [ //listcolumns暂不展示 ], listauth: [] } }, mounted() {}, methods: {}, created() { //console.log("authotable_expend created: " + JSON.stringify(this.row.children)) var object = this.row.children; console.log("auth expand data:" + JSON.stringify(object)) this.listauth.splice(0) object.forEach(r = >{ this.listauth.push(r) }) //console.log("listauth:" + JSON.stringify(this.listauth)) } }   td.ivu-table-expanded-cell{ padding:0; }   

注意,添加td.ivu-table-expanded-cell{padding:0;},可以是扩展部分内容充满全部,展示效果如下

在expand.vue里递归调用自身,可以逐级扩展

总结:

目前在Vue.js的2个主要的前端组件iView和ElementUI都暂时没有看到合适的可扩展的树形表,只有自己编写相关组件来实现。相信以后应该都会有的,就像之前iView多表头都没有,后面也终于添加了。

此外,自定义组合树形权限表还有部分功能没有完善,如:

1如果当前节点没有子节点,就不应该出现扩展的按钮本文来源gaodaimacom搞#代%码@网-

2扩展按钮最好按照树的深度逐渐向后移动

3序号未按总序号排列

预期结果应该类似于:

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

您可能感兴趣的文章:

  • vue iview实现动态路由和权限验证功能
  • iview 权限管理的实现

以上就是详解Vue.js iview实现树形权限表(可扩展表)的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:详解Vue.js iview实现树形权限表(可扩展表)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址