NoteZ_技术博客 NoteZ_技术博客
🏠 首页
  • 📚 Web技术
  • 📋 Npm笔记
  • 📑 Markdown
  • 📄 Git笔记
  • 📝 Nginx文档
  • 📓 Linux文档
  • 📖 技术文档
  • 📜 其他文档
  • 🧊 NodeJs
  • 🎡 Express
  • 🔥 Rust
  • 🎉 Koa2
  • 🍃 MongoDB
  • 🐬 MySql
  • 🥦 Oracle
  • 🍁 Python
  • 🍄 JavaScript
  • 🌰 CSS
  • 🧄 HTML
  • 🥑 Canvas
  • 🌽 Nuxt
  • 🍆 React
  • 🥜 Vue
  • 🧅 TypeScript
  • 🌶️ AI
  • 📘 分类
  • 📗 标签
  • 📙 归档
⚜️ 在线编辑 (opens new window)
  • 📁 站点收藏
  • 📦 前端组件库
  • 📊 数据可视化
  • 🌈 开源插件
  • 🎗️ 关于我
  • 🔗 友情链接
GitHub (opens new window)

NoteZ_技术博客

前端界的小学生
🏠 首页
  • 📚 Web技术
  • 📋 Npm笔记
  • 📑 Markdown
  • 📄 Git笔记
  • 📝 Nginx文档
  • 📓 Linux文档
  • 📖 技术文档
  • 📜 其他文档
  • 🧊 NodeJs
  • 🎡 Express
  • 🔥 Rust
  • 🎉 Koa2
  • 🍃 MongoDB
  • 🐬 MySql
  • 🥦 Oracle
  • 🍁 Python
  • 🍄 JavaScript
  • 🌰 CSS
  • 🧄 HTML
  • 🥑 Canvas
  • 🌽 Nuxt
  • 🍆 React
  • 🥜 Vue
  • 🧅 TypeScript
  • 🌶️ AI
  • 📘 分类
  • 📗 标签
  • 📙 归档
⚜️ 在线编辑 (opens new window)
  • 📁 站点收藏
  • 📦 前端组件库
  • 📊 数据可视化
  • 🌈 开源插件
  • 🎗️ 关于我
  • 🔗 友情链接
GitHub (opens new window)
  • JavaScript笔记

    • ajax如何解决跨域问题
    • async与await语法
    • Axios 文件下载实现进度条功能
    • Axios 的各种请求方式及传参格式总结
    • axios简单使用
    • CommonJS与ES6 Module的导入与导出之间的区别
    • ES6 中 export,export default 和 import 区别及用法
    • Javascript - 如何循环遍历getElementsByClassName返回的所有DOM元素
    • JavaScript 实现 charts 缩放比例尺
    • javaScript 实现将文件流下载文件保存到本地
    • JavaScript 数组对象去重方法
    • JavaScript 生成 uuid
    • JavaScript 解析 get 请求 url 参成对象
    • JavaScript判断字符串中是否包含某个字符串
    • JavaScript判断是否为移动端浏览器
    • JavaScript复制内容到剪贴板的两种常用方法
    • JavaScript实现单词首字母大写的方法总汇
    • JavaScript对时间(time)、日期(date)格式转换
    • JavaScript数组去重方法总结
    • JavaScript数组类型(Array)操作方法汇总
    • JavaScript浅度和深度复制的实现方法
    • js 中的 ES5 面向对象
    • js 中的 ES6 面向对象
    • js 中的 new 命令原理
    • js 实现 iframe通信
    • js 实现将文本复制到粘贴板
    • js 异步操作
    • js 数组转为树形(tree)结构
    • js 文件分片上传
    • js 统计数组中元素的重复次数
    • JS 选中文本输入框的部分文本内容
    • js 面向对象总结
    • Js中的forEach()、map()、$.each()和$.map()之间异同
    • js中的多种数组去重性能对比总结
    • js判断移动端还是pc端
    • JS如何监听div的resize事件
    • js实现格式化JSON数据方法
    • js实现防抖与节流函数
    • Js将滚动条(scrollbar)保持在最底部的方法
    • JS异步编程进化之路
    • JS数组改变元素位置(互换、置顶、上移、下移)
    • js数组的简单使用
    • js文件单位大小转换
    • JS获取和修改url参数
    • JS获取浏览器信息
    • js获取浏览器可视区或页面大小的兼容性总结
    • JS读取本地文本文件(兼容各种浏览器)
    • js随机打乱数组
    • Promise 中的 async 与 await 特点
    • Promise封装请求
    • qs.stringify 的基本用法
    • Web worker 使用方法
    • window.open之浏览器新窗口打开
    • 使用 js 实现保存 .tree 文件到本地
    • 使用 JS 将数字转化成千分位
    • 使用 js 快速计算文件 hash 值
    • 使用 js 进行Base64编码、解码(js-base64)
    • 使用 setTimeout 解决 setInterval 计时器不准的问题
    • 使用js在树形(tree)结构中找到子节点的父级路径
    • 使用JS如何判断远程网络图片地址是否失效
    • 使用js操作浏览器cookie的设置,读取,删除
    • 使用JS解决PC端页面适配方案
    • 使用js递归生成树形结构
    • 使用原生js(input type = file)上传图片(Base64)限制大小、类型判断、像素判断
    • 关于JavaScript 数组的复制解析总结
    • 关于JavaScript数组方法使用总结
    • 内置对象
    • 前端 DOM 总结
    • 前端 js 基础总结
    • 前端使用 jszip 解压 .zip 文件获取 file 格式文件
    • 前端各种事件总结
    • 前端常用的JS(代码片段)小工具方法总结
    • 前端登录界面常用的JS小工具方法总结
    • 十六(16)进制与rgb颜色转换
    • 原生 JavaScript 实现 div 随意拖拽原生 JavaScript 实现 div 随意拖拽
    • 原生 JS 实现页面树形(tree)菜单展示功能
      • 简单的树结构
      • 菜单树结构
    • 原生js实现 table表格列宽拖拽
    • 原生js获取iframe中dom元素或父级元素
    • 如何使用 file-saver 导出文件到本地?
    • 如何使用js将目录路径list转成tree树结构
    • 实现对localStorage、sessionStorage高级封装
    • 将一维数组按指定长度转为二维数组
    • 将网站设为主页以及加入收藏功能实现方法
    • 总结 3 种 HTML 转 PDF 导出的方案
    • 比typeof运算符更准确的js类型判断
    • 浏览器模型
    • 监听滚动条事件-返回顶部的方法
    • 简析JavaScript中的事件委托问题
    • 返回顶部的通用Js方法
    • 非常实用的Js代码工具片段
    • JS_根据鼠标位置缩放元素、拖拽
    • js_登录验证码绘制
    • JS-以鼠标位置为中心的滑轮缩放-图片
    • js生成目录并实现目录节点跟随滚动高亮
    • 使用js实现标题跳转与复制实现方法
    • 使用原生js动态实现文件的上传功能
    • 使用原生js提取md中的图片信息
    • 3d-force-graph使用方法
    • js 前端(web)浏览器端读取文件目录
    • 原生js监听窗口大小变化
    • JS 中 Promise 用法(简要总结)
  • CSS笔记

  • HTML笔记

  • Canvas笔记

  • Nuxt笔记

  • React笔记

  • Vue笔记

  • TypeScript笔记

  • AI相关笔记

  • 开发文档
  • JavaScript笔记
NoteZ
2020-09-18
目录

原生 JS 实现页面树形(tree)菜单展示功能

# 简单的树结构

css 部分

.tree-box ul {
    margin-left: 40px;
}
.tree-box ul li{
    margin: 2px 0;
}
.tree-box ul li span{
    margin-left: 5px;
}
1
2
3
4
5
6
7
8
9

html 部分

<div class="tree-box">
    <ul id="treeBox"></ul>
</div>
1
2
3

JS 部分

function generate(menus, par, deep) {
    for (let i = 0; i < menus.length; i++) {
        let obj = menus[i]; 
        obj.deep = deep
        let ele = document.createElement('li');

        if (obj.level === '1') {
            ele.innerHTML = '●' + `<span>${obj.name}</span>`;
        } else if (obj.level === '2') {
            ele.innerHTML = '▲' + `<span>${obj.name}</span>`;
        } else {
            ele.innerHTML = '■' + `<span>${obj.name}</span>`;
        }

        if (obj.children) {
            let nextpar = document.createElement('ul');
            ele.appendChild(nextpar);
            this.generate(obj.children, nextpar, deep + 1);
        }
        par.appendChild(ele);
    }
};

// 使用
let datajson = {
   name:"标题1",,
   children:[{
        name:"标题1-1",,
        children:[{
            
        }]
   },{
        name:"标题1-2",
        children:[{
            name:"标题1-2-1",,
        }]
   }]
}
generate([datajson], document.querySelector('#treeBox'), 0)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39

# 菜单树结构

css 部分

/**
 * DOM树
 */
ul>li{
    list-style: none;
}
/* 可展开*/
.switch-open {
    margin-left:-12px;
    border:6px solid transparent;
    display:inline-block;
    width:0px;
    height:0px;
    border-top-color: black;
    margin-right: 5px;
}
/* 展开完毕*/
.switch-close {
    margin-left:-12px;
    border:6px solid transparent;
    display:inline-block;
    width:0px;
    height:0px;
    border-left-color: black;
    margin-bottom: 2px;
    margin-right: 5px;
}

/* 改变CheckBox样式*/
input[type='checkbox']{
    width: 20px;
    height: 20px;
    -webkit-appearance:none;
    -moz-appearance: none;
    border: 1px solid #c9c9c9;
    border-radius: 3px;
    outline: none;
    color:white;
    text-align: center;
    margin-right: 5px;
}

input[type='checkbox']:before {
    content: '√ ';
    color:transparent;
}

input[type=checkbox]:checked{
    background-color: #409eff;
}

input[type=checkbox]:checked:before{
    content: '√';
    color:white;
    font-weight: bold;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56

js 部分

//这里生成DOM
function generate(menus, par) {
    for (var i = 0; i < menus.length; i++) {
        var wzAuthority = menus[i];
        var ele = document.createElement('li');
        if(wzAuthority.children !== null && wzAuthority.children.length == 0) {
            if (wzAuthority.checked) {
                ele.innerHTML=' <input type="checkbox" οnclick="checkSingleChange(this)" checked="true" value="' + wzAuthority.id + '"></input>'+wzAuthority.authorityName;
            } else {
                ele.innerHTML=' <input type="checkbox" οnclick="checkSingleChange(this)"  value="' + wzAuthority.id + '"></input>'+wzAuthority.authorityName;
            }
            // ele.innerHTML=' <input type="checkbox" οnclick="checkSingleChange(this)"  value="' + wzAuthority.id + '"></input>'+wzAuthority.authorityName;
        } else {
            if (wzAuthority.checked) {
                ele.innerHTML='<span><span class="switch-open" οnclick="toggle(this)"></span><input type="checkbox" checked="true" οnclick="checkChange(this)" value="' + wzAuthority.id + '"></input>' + wzAuthority.authorityName + '</span>';
            } else {
                ele.innerHTML='<span><span class="switch-open" οnclick="toggle(this)"></span><input type="checkbox" οnclick="checkChange(this)" value="' + wzAuthority.id + '"></input>' + wzAuthority.authorityName + '</span>';
            }
            // ele.innerHTML='<span><span class="switch-open" οnclick="toggle(this)"></span><input type="checkbox" οnclick="checkChange(this)" value="' + wzAuthority.id + '"></input>' + wzAuthority.authorityName + '</span>';
            var nextpar = document.createElement('ul');
            ele.appendChild(nextpar);
            generate(wzAuthority.children, nextpar);
        }
        par.appendChild(ele);
    }
}

//处理展开和收起
function toggle(eve) {
    var par=eve.parentNode.nextElementSibling;
    if(par.style.display=='none') {
        par.style.display='block';
        eve.className='switch-open';
    } else {
        par.style.display='none';
        eve.className='switch-close';
    }
}

//处理全部勾选和全部不选
function checkChange(eve) {
    var oul = eve.parentNode.nextElementSibling;
    var parent = oul.parentNode.firstChild.childNodes.item(1);
    if(eve.checked) {
        parent.setAttribute("checked", "true");
        for(var i=0;i<oul.querySelectorAll('input').length;i++) {
            if ("true" != oul.querySelectorAll('input')[i].getAttribute("checked")) {
                oul.querySelectorAll('input')[i].setAttribute("checked", "true");
            }
        }
    } else {
        parent.setAttribute("checked","false");
        console.log('当前元素---',oul)
        for(var i=0;i<oul.querySelectorAll('input').length;i++) {
            oul.querySelectorAll('input')[i].removeAttribute("checked");
        }
    }

}

//处理单个勾选和单个不选
function checkSingleChange(eve) {
    console.log(eve)
    if(eve.checked) {
        eve.setAttribute("checked", "true");
        //子元素选中,则父元素选中
        console.log(eve.parentNode.parentNode.previousSibling.childNodes.item(1))
        eve.parentNode.parentNode.previousSibling.childNodes.item(1).setAttribute("checked", "true");
    } else {
        eve.removeAttribute("checked");
        //如果子元素全部清除,父元素也取消选中
        for(var i=0;i<eve.parentNode.parentNode.querySelectorAll('input').length;i++) {
            let inputElement = eve.parentNode.parentNode.querySelectorAll('input')[i];
            if (inputElement.getAttribute("checked") == "true") {
                return;
            }
        }
        eve.parentNode.parentNode.previousSibling.childNodes.item(1).removeAttribute("checked");
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80

html 部分

<div class="warp">
	<ul id="container">
	</ul>
</div>
1
2
3
4

使用部分

let dataJson =  {
    "menus": [
        {
            "id": "2",
            "authorityName": "账号中心",
            "type": 0,
            "path": null,
            "level": null,
            "parentId": "0",
            "isRequireAuth": null,
            "createTime": null,
            "updateTime": null,
            "children": [
                {
                    "id": "32",
                    "authorityName": "账号列表",
                    "type": 0,
                    "path": null,
                    "level": null,
                    "parentId": "2",
                    "isRequireAuth": null,
                    "createTime": null,
                    "updateTime": null,
                    "children": [
                        {
                            "id": "33",
                            "authorityName": "列表接口",
                            "type": 0,
                            "path": null,
                            "level": null,
                            "parentId": "32",
                            "isRequireAuth": null,
                            "createTime": null,
                            "updateTime": null,
                            "children": []
                        }
                    ]
                },
                {
                    "id": "91",
                    "authorityName": "角色列表",
                    "type": 0,
                    "path": null,
                    "level": null,
                    "parentId": "2",
                    "isRequireAuth": null,
                    "createTime": null,
                    "updateTime": null,
                    "children": []
                }
            ]
        },
        {
            "id": "89",
            "authorityName": "企业中心",
            "type": 0,
            "path": null,
            "level": null,
            "parentId": "0",
            "isRequireAuth": null,
            "createTime": null,
            "updateTime": null,
            "children": [
                {
                    "id": "86",
                    "authorityName": "变更管理",
                    "type": 0,
                    "path": null,
                    "level": null,
                    "parentId": "89",
                    "isRequireAuth": null,
                    "createTime": null,
                    "updateTime": null,
                    "children": [
                        {
                            "id": "49",
                            "authorityName": "列表接口",
                            "type": 0,
                            "path": null,
                            "level": null,
                            "parentId": "86",
                            "isRequireAuth": null,
                            "createTime": null,
                            "updateTime": null,
                            "children": []
                        }
                    ]
                }
            ]
        }
    ],
    "checkedKeys": []
}; 

generate([dataJson], document.getElementById('container'));
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#JavaScript
上次更新: 2024/01/30, 00:35:17
原生 JavaScript 实现 div 随意拖拽原生 JavaScript 实现 div 随意拖拽
原生js实现 table表格列宽拖拽

← 原生 JavaScript 实现 div 随意拖拽原生 JavaScript 实现 div 随意拖拽 原生js实现 table表格列宽拖拽→

最近更新
01
Gitea数据备份与还原
03-10
02
Linux 中使用 rsync 同步文件目录教程
03-10
03
Linux 使用 rsync 互相传输同步文件的简单步骤
03-08
更多文章>
Theme by Vdoing | Copyright © 2019-2025 NoteZ,All rights reserved | 冀ICP备2021027292号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式