IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> js中将有层级关系的一维数据转换为父子级关系的二维数据、菜单权限三级层级数据实现(树形结构数据) -> 正文阅读

[JavaScript知识库]js中将有层级关系的一维数据转换为父子级关系的二维数据、菜单权限三级层级数据实现(树形结构数据)

很久没有发文了,今天发点不一样的,如下:

  <script>
    // 一维数据:
    let arrData=[
      { r_id: 1, role_name: '开发商', n_id: 1, txt: '主页' },
      { r_id: 1, role_name: '开发商', n_id: 2, txt: '项目' },
      { r_id: 1, role_name: '开发商', n_id: 3, txt: '报警' },
      { r_id: 1, role_name: '开发商', n_id: 4, txt: '客户' },
      { r_id: 1, role_name: '开发商', n_id: 5, txt: '设备' },
      { r_id: 1, role_name: '开发商', n_id: 6, txt: '设置' },
      { r_id: 1, role_name: '开发商', n_id: 7, txt: '集中监控' },
      { r_id: 1, role_name: '开发商', n_id: 9, txt: '用户列表' },
      { r_id: 1, role_name: '开发商', n_id: 10, txt: '系统设置' },
      { r_id: 1, role_name: '开发商', n_id: 11, txt: '报警设置' },
      { r_id: 1, role_name: '开发商', n_id: 12, txt: '我的项目' },
      { r_id: 1, role_name: '开发商', n_id: 13, txt: '增加项目' },
      { r_id: 1, role_name: '开发商', n_id: 14, txt: '权限' },
      { r_id: 1, role_name: '开发商', n_id: 15, txt: '角色列表' },
      { r_id: 1, role_name: '开发商', n_id: 16, txt: '权限列表' },
      { r_id: 1, role_name: '开发商', n_id: 17, txt: '报警日志' },
      { r_id: 1, role_name: '开发商', n_id: 18, txt: '报警管理' },
      { r_id: 1, role_name: '开发商', n_id: 19, txt: '设备列表' },
      { r_id: 2, role_name: '厂商', n_id: 1, txt: '主页' },
      { r_id: 2, role_name: '厂商', n_id: 2, txt: '项目' },
      { r_id: 3, role_name: '用户', n_id: 2, txt: '项目' },
      { r_id: 3, role_name: '用户', n_id: 1, txt: '主页' },
      { r_id: 4, role_name: '普通员工', n_id: 3, txt: '报警' },
      { r_id: 4, role_name: '普通员工', n_id: 5, txt: '设备' }
    ]

    // 进行转换:
    let newArr = [...new Set(arrData.map(item => item.role_name))] // 找出arrData数据中的role_name的多个数据:{role_name:'值'},通过set去重,之后在解构成数组:[]
    let list = []
    newArr.forEach(names => {
        list.push(arrData.filter(item => item.role_name === names))
    })
    let mlist = []
    list.forEach((e,i)=>{
        let arr = []
        e.forEach(its=>{
            arr.push({
                n_id:its.n_id,
                txt:its.txt
            })
        })
        mlist.push({
            r_id:e[0].r_id,
            role_name:newArr[i],
            children: arr
        })
    })

    console.log(mlist)
    //转换后具有父子级关系的数据console.log(mlist)打印的结果如下:
    [
      {
        r_id: 1,
        role_name: '开发商',
        children: [
          { n_id: 1, txt: '主页' },
          { n_id: 2, txt: '项目' },
          { n_id: 3, txt: '报警' },
          { n_id: 4, txt: '客户' },
          { n_id: 5, txt: '设备' },
          { n_id: 6, txt: '设置' },
          { n_id: 7, txt: '集中监控' },
          { n_id: 9, txt: '用户列表' },
          { n_id: 10, txt: '系统设置' },
          { n_id: 11, txt: '报警设置' },
          { n_id: 12, txt: '我的项目' },
          { n_id: 13, txt: '增加项目' },
          { n_id: 14, txt: '权限' },
          { n_id: 15, txt: '角色列表' },
          { n_id: 16, txt: '权限列表' },
          { n_id: 17, txt: '报警日志' },
          { n_id: 18, txt: '报警管理' },
          { n_id: 19, txt: '设备列表' }
        ]
      },
      {
        r_id: 2,
        role_name: '厂商',
        children: [ { n_id: 1, txt: '主页' }, { n_id: 2, txt: '项目' } ]
      },
      {
        r_id: 3,
        role_name: '用户',
        children: [ { n_id: 2, txt: '项目' }, { n_id: 1, txt: '主页' } ]
      },
      {
        r_id: 4,
        role_name: '普通员工',
        children: [ { n_id: 3, txt: '报警' }, { n_id: 5, txt: '设备' } ]
    }]

    // 对let newArr = [...new Set(arrData.map(item => item.role_name))]的详细解说如下:
    let obj = arrData.map(item => item.role_name) 
    console.log(obj) //['开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '开发商', '厂商', '厂商', '用户', '用户', '普通员工', '普通员工']
    let res = new Set(obj)
    console.log(res) //{'开发商', '厂商', '用户', '普通员工'}
    let arrs = [...res]
    console.log(arrs) //['开发商', '厂商', '用户', '普通员工']






    

    // 注意:上面只是简单的实现具有层级关系的数据处理,实际工作中常常出现三级层级关系的数据,就权限功能而言,每个主菜单(一级菜单)和负极菜单(二级菜单或更多级菜单)之间应该是嵌套的父子级关系,而并非是上面的同级非嵌套关系,优化后的代码如下:
    let arrdatas=[
      {r_id: 1,role_name: '开发商',n_id: 1,txt: '主页',pid: null},
      {r_id: 1,role_name: '开发商',n_id: 2,txt: '项目',pid: null},
      {r_id: 1,role_name: '开发商',n_id: 3,txt: '报警',pid: null},
      {r_id: 1,role_name: '开发商',n_id: 4,txt: '客户',pid: null},
      {r_id: 1,role_name: '开发商',n_id: 5,txt: '设备',pid: null},
      {r_id: 1,role_name: '开发商',n_id: 6,txt: '设置',pid: null},
      {r_id: 1,role_name: '开发商',n_id: 7,txt: '集中监控',pid: 1},
      {r_id: 1,role_name: '开发商',n_id: 9,txt: '用户列表',pid: 4},
      {r_id: 1,role_name: '开发商',n_id: 10,txt: '系统设置',pid: 6},
      {r_id: 1,role_name: '开发商',n_id: 11,txt: '报警设置',pid: 6},
      {r_id: 1,role_name: '开发商',n_id: 12,txt: '我的项目',pid: 2},
      {r_id: 1,role_name: '开发商',n_id: 13,txt: '增加项目',pid: 2},
      {r_id: 1,role_name: '开发商',n_id: 14,txt: '权限',pid: null},
      {r_id: 1,role_name: '开发商',n_id: 15,txt: '角色列表',pid: 14},
      {r_id: 1,role_name: '开发商',n_id: 16,txt: '权限列表',pid: 14},
      {r_id: 1,role_name: '开发商',n_id: 17,txt: '报警日志',pid: 3},
      {r_id: 1,role_name: '开发商',n_id: 18,txt: '报警管理',pid: 3},
      {r_id: 1,role_name: '开发商',n_id: 19,txt: '设备列表',pid: 5},
      {r_id: 2,role_name: '厂商',n_id: 1,txt: '主页',pid: null},
      {r_id: 2,role_name: '厂商',n_id: 2,txt: '项目',pid: null},
      {r_id: 3,role_name: '用户',n_id: 2,txt: '项目',pid: null},
      {r_id: 3,role_name: '用户',n_id: 1,txt: '主页',pid: null},
      {r_id: 4,role_name: '普通员工',n_id: 3,txt: '报警',pid: null},
      {r_id: 4,role_name: '普通员工',n_id: 5,txt: '设备',pid: null}
    ]


    let newarr = [...new Set(arrdatas.map(item => item.role_name))]
    let lists = []
    newarr.forEach(names => {
        lists.push(result.filter(item => item.role_name === names))
    })
    let mlists = []
    list.forEach((e,i)=>{
      let arr = []
      e.forEach(its=>{
          arr.push({
              n_id:its.n_id,
              txt:its.txt,
              pid:its.pid
          })
      })
      // 对没有层级关系的菜单数组进arr行处理的方法:
      function tree(data,pid,child){
          let parents = data.filter(p => p[pid] === null),
             children = data.filter(c => c[pid] !== null);
          function dataToTree(parents, children){
              parents.map(p => {
                  children.map((c, i) => {
                      if(c[pid] === p.n_id){
                          let _children = JSON.parse(JSON.stringify(children));
                          _children.splice(i, 1);
                          dataToTree([c], _children);
                          if(p[child]){
                              p[child].push(c);
                           }else{
                              p[child] = [c];
                          };
                      };
                  });
              });
          };
          dataToTree(parents, children);
          return parents;
      };
      let arrTree = tree(arr,'pid','childs');//调用方法最终实现具有嵌套关系的层级菜单数组
      mlists.push({
          r_id:e[0].r_id,
          role_name:newArr[i],
          childrens: arrTree
      })
    })
    // 最终实现的三级菜单效果如下图:
  </script>

三级权限菜单数据如下图:
在这里插入图片描述

提示:本文图片等素材来源于网络,若有侵权,请发邮件至邮箱:810665436@qq.com联系笔者删除。
笔者:苦海

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-09 18:14:27  更:2022-04-09 18:15:10 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 0:30:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码