JavaScript 树状菜单栏jQuery写法

简介: JavaScript 树状菜单栏jQuery写法

这里就不多叨叨啦!只是换了种写法

let data; // 定义用于存储请求返回数据的变量
let arr = []; // 定义用于存储处理后的树形数据的数组
 
$(document).ready(function () {
    let xhr = $.ajax({
        url: './js/tree.json', // 请求地址
        method: 'GET', // 请求方式
        dataType: 'json', // 响应数据类型
        success: function (response) {
            data = response; // 将返回的 JSON 数据存储在 data 变量中
            arr = tree_menue(data, 0, []); // 调用递归函数,从根节点开始构建树形结构
            console.log(arr); // 打印构建完成的树形数据结构
            rendertree(arr); // 调用渲染树的函数并传入树形数据
        }
    });
});
 
function tree_menue(data, pid, arr) {
    for (let i = 0; i < data.length; i++) {
        if (data[i].pid == pid) {
            // 递归调用,构建当前节点的子节点数组
            data[i].children = tree_menue(data, data[i].id, []);
            // 将当前节点加入到父节点的 children 数组中
            arr.push(data[i]);
        }
    }
    return arr;
}
 
// 渲染树形结构的函数
function inn(data, pid, arr) {
    for (let i = 0; i < data.length; i++) {
        if (data[i].pid == pid) {
            data[i].children = inn(data, data[i].id, []);
            arr.push(data[i]);
        }
    }
    return arr;
}
 
// 渲染树形结构的函数
function rendertree(data) {
    let str = `<div class="tree_wrap">`;
 
    for (let i = 0; i < data.length; i++) {
        if (data[i].children.length > 0) {
            str +=
                `<div class="tree_flex">
                    <img src="${data[i].icon}" alt="" class="con">${data[i].name}
                    <span><img src="./img/wode.png" alt="" class="cons"></span>
                </div>
                <div style="display:none">`;
 
            str += rendertree(data[i].children);
 
            str += `</div>`;
        } else {
            str +=
                `<div class="tree_left">
                    <img src="${data[i].icon}" alt="" class="con">${data[i].name}
                </div>`;
        }
    }
 
    str += `</div>`;
    $('.treemenu').html(str); // 将树形结构渲染到页面上的指定位置
    return str;
}
 
// 获取所有类名为 'tree_left' 的元素 进行添加点击事件
$(document).on('click', '.tree_flex', function () {
    // 获取当前节点的下一个兄弟元素,即子节点容器
    let children = $(this).next();
    // 设置箭头图标的过渡效果为1秒
    $(this).find('.cons').css('transition', 'transform 1s');
    // 判断子节点容器的显示状态
    if (children.css('display') == 'block') {
        // 要是字节点是显示的,则隐藏它
        // children.css('display', 'none');
        children.hide(2000);
        // 当不点击箭头的时候让箭头图标旋转角度为0度,折叠状态
        $(this).find('.cons').css('transform', 'rotate(0deg)');
    } else {
        children.show(2000);
        // 要是字节点是隐藏的,则显示它
        // children.css('display', 'block');
        // 当点击箭头后让箭头图标旋转角度为180度,展开状态
        $(this).find('.cons').css('transform', 'rotate(180deg)');
        // $(this).find('.cons').css('transition', 'transform 1s');
    }
});

附带淡入淡出效果哟家人们

相关文章
|
6月前
|
JavaScript
鼠标事件(点击换色)分别使用js和jQuery代码实现
鼠标事件(点击换色)分别使用js和jQuery代码实现
54 1
|
3月前
|
JavaScript 前端开发
js+jquery实现贪吃蛇经典小游戏
本项目采用HTML、CSS、JavaScript和jQuery技术,无需游戏框架支持。通过下载项目文件至本地,双击index.html即可启动贪吃蛇游戏。游戏界面简洁,支持方向键控制蛇移动,空格键实现游戏暂停与恢复功能。
89 14
|
4月前
|
JavaScript 前端开发 开发者
jQuery:JavaScript库的瑰宝
jQuery:JavaScript库的瑰宝
100 3
|
4月前
|
JavaScript 前端开发 API
深入了解jQuery:快速、高效的JavaScript库
【10月更文挑战第11天深入了解jQuery:快速、高效的JavaScript库
51 0
|
4月前
|
JavaScript 前端开发
JavaScript - 测试 jQuery
JavaScript - 测试 jQuery
30 0
|
4月前
|
JavaScript 前端开发
JavaScript三级联动jQuery写法
JavaScript三级联动jQuery写法
|
4月前
|
JavaScript 前端开发 API
【前端基础篇】JavaScript之jQuery介绍
【前端基础篇】JavaScript之jQuery介绍
234 0
|
6月前
|
JavaScript
分别用jquery和js修改页面元素
分别用jquery和js修改页面元素
48 2
|
6月前
|
JavaScript 前端开发 开发者
jQuery:JavaScript库的瑰宝
jQuery:JavaScript库的瑰宝
128 4
|
6月前
|
JavaScript Java
点击按钮,向下添加目录。Java script+jQuery写法
点击按钮,向下添加目录。Java script+jQuery写法
43 1

热门文章

最新文章

  • 1
    当面试官再问我JS闭包时,我能答出来的都在这里了。
    49
  • 2
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    29
  • 3
    Node.js 中实现多任务下载的并发控制策略
    34
  • 4
    【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
    26
  • 5
    【JavaScript】深入理解 let、var 和 const
    49
  • 6
    【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
    47
  • 7
    【03】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架搭建-服务端-后台管理-整体搭建-优雅草卓伊凡商业项目实战
    57
  • 8
    【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
    57
  • 9
    如何通过pm2以cluster模式多进程部署next.js(包括docker下的部署)
    72
  • 10
    【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
    57