讲师中心 微信公众号

扫码关注官方订阅号

注册 / 登录
首页
文章
后端开发 web前端 数据库 开发工具 php框架 常见问题 人工智能 Java 系统教程 电脑教程 硬件教程 手机教程 软件教程 游戏教程 自媒体 新闻
专题
后端开发 web前端 数据库 开发工具 php框架 人工智能 Java 系统教程 电脑教程 硬件教程 手机教程 软件教程 游戏教程 新闻
AI工具
AI 聊天问答 Agent智能体 AI 文本写作 AI 绘画作图 AI 设计工具 AI 视频创作 AI 音频制作 AI 办公学习 AI 编程开发 AI 提示词
学习
大前端 后端开发 数据库 移动端 运维开发 计算机基础
编程手册
大前端 后端开发 数据库 移动端 运维开发 计算机基础
下载
js特效 网站源码 工具下载 类库下载 网站素材 学习资源 插件扩展 手机游戏
最近更新
当前位置:首页 > web前端 > js教程 >

正文

0

0

值得分享的Bootstrap Ace模板实现菜单和Tab页效果_javascript技巧

php中文网

php中文网

发布时间:2016-05-16 15:22:39

|

2620人浏览过

|

来源于php中文网

原创

本文分享了项目中使用Ace模板的菜单样式和基于iframe的Tab页效果。

一、效果展示

折腾了好久,终于将菜单样式和Tab页的效果从项目中抽出来了。

1、初始加载出来的效果

2、展开菜单(支持多级展开,后面代码介绍)

3、点击子菜单,以Tab页的形式打开对应的页面

立即学习“Java免费学习笔记(深入)”;

4、支持菜单折叠

5、打开的菜单过多时自动换行显示,折叠后自适应

二、代码示例
有现成的东西用很方便的,总的来说Bootstrap Ace模板的功能还是比较强大的,并且支持各种终端设备。本文主要使用的它的菜单的效果,下面就来看看Ace模板菜单效果的实现代码。

1、菜单效果
由于Ace是基于Bootstrap的,所以首先需要引用jquery和bootstrap组件,先来总的看看它需要引用哪些文件吧。  



  
  

  
  
  
  

  
  

  

呵呵,看着还是挺多的吧。除了最后一个js文件()是博主自己封装的,其他基本都是些组件需要的特性组件。看看页面上面要放哪些html标签:   

 

    再来看看sidebar-menu.js这个文件里面封装的方法:

    萝卜简历
    萝卜简历

    免费在线AI简历制作工具,帮助求职者轻松完成简历制作。

    下载
    (function ($) {
      $.fn.sidebarMenu = function (options) {
        options = $.extend({}, $.fn.sidebarMenu.defaults, options || {});
        var target = $(this);
        target.addClass('nav');
        target.addClass('nav-list');
        if (options.data) {
          init(target, options.data);
        }
        else {
          if (!options.url) return;
          $.getJSON(options.url, options.param, function (data) {
            init(target, data);
          });
        }
        var url = window.location.pathname;
        //menu = target.find("[href='" + url + "']");
        //menu.parent().addClass('active');
        //menu.parent().parentsUntil('.nav-list', 'li').addClass('active').addClass('open');
        function init(target, data) {
          $.each(data, function (i, item) {
            var li = $('
  • '); var a = $(''); var icon = $(''); //icon.addClass('glyphicon'); icon.addClass(item.icon); var text = $(''); text.addClass('menu-text').text(item.text); a.append(icon); a.append(text); if (item.menus&&item.menus.length>0) { a.attr('href', '#'); a.addClass('dropdown-toggle'); var arrow = $(''); arrow.addClass('arrow').addClass('icon-angle-down'); a.append(arrow); li.append(a); var menus = $('
      '); menus.addClass('submenu'); init(menus, item.menus); li.append(menus); } else { var href = 'javascript:addTabs({id:\'' + item.id + '\',title: \'' + item.text + '\',close: true,url: \'' + item.url + '\'});'; a.attr('href', href); //if (item.istab) // a.attr('href', href); //else { // a.attr('href', item.url); // a.attr('title', item.text); // a.attr('target', '_blank') //} li.append(a); } target.append(li); }); } } $.fn.sidebarMenu.defaults = { url: null, param: null, data: null }; })(jQuery);

      在页面上面直接调用sidebar-menu的方法

      $(function () {
            $('#menu').sidebarMenu({
              data: [{
                id: '1',
                text: '系统设置',
                icon: 'icon-cog',
                url: '',
                menus: [{
                  id: '11',
                  text: '编码管理',
                  icon: 'icon-glass',
                  url: '/CodeType/Index'
                }]
              }, {
                id: '2',
                text: '基础数据',
                icon: 'icon-leaf',
                url: '',
                menus: [{
                  id: '21',
                  text: '基础特征',
                  icon: 'icon-glass',
                  url: '/BasicData/BasicFeature/Index'
                }, {
                  id: '22',
                  text: '特征管理',
                  icon: 'icon-glass',
                  url: '/BasicData/Features/Index'
                }, {
                  id: '23',
                  text: '物料维护',
                  icon: 'icon-glass',
                  url: '/Model/Index'
                }, {
                  id: '24',
                  text: '站点管理',
                  icon: 'icon-glass',
                  url: '/Station/Index'
                }]
              }, {
                id: '3',
                text: '权限管理',
                icon: 'icon-user',
                url: '',
                menus: [{
                  id: '31',
                  text: '用户管理',
                  icon: 'icon-user',
                  url: '/SystemSetting/User'
                }, {
                  id: '32',
                  text: '角色管理',
                  icon: 'icon-apple',
                  url: '/SystemSetting/Role'
                }, {
                  id: '33',
                  text: '菜单管理',
                  icon: 'icon-list',
                  url: '/SystemSetting/Menu'
                }, {
                  id: '34',
                  text: '部门管理',
                  icon: 'icon-glass',
                  url: '/SystemSetting/Department'
                }]
              }, {
                id: '4',
                text: '订单管理',
                icon: 'icon-envelope',
                url: '',
                menus: [{
                  id: '41',
                  text: '订单查询',
                  icon: 'icon-glass',
                  url: '/Order/Query'
                }, {
                  id: '42',
                  text: '订单排产',
                  icon: 'icon-glass',
                  url: '/Order/PLANTPRODUCT'
                }, {
                  id: '43',
                  text: '订单撤排',
                  icon: 'icon-glass',
                  url: '/Order/cancelPRODUCT'
                }, {
                  id: '44',
                  text: '订单HOLD',
                  icon: 'icon-glass',
                  url: '/Order/hold'
                }, {
                  id: '45',
                  text: '订单删除',
                  icon: 'icon-glass',
                  url: '/Order/delete'
                }, {
                  id: '47',
                  text: '订单插单',
                  icon: 'icon-glass',
                  url: '/Order/insertorder'
                }, {
                  id: '48',
                  text: '订单导入',
                  icon: 'icon-glass',
                  url: '/Order/Import'
                }]
              }]
            });
          });
      

      这里需要说明的很重要的一点就是关于菜单前面的小图标:

      con的值为icon-user的时候,菜单上面就会显示一个如图的小图标。当然一般情况下,菜单肯定是动态加载的的,如果需要从后台取数据,可以直接调用此方法:

      $('#menu').sidebarMenu({ url: "/api/UserApi/GetMenuByUser/", param: { strUser: 'admin' } });
      即可,呵呵,很简单吧。

      2、Tab页效果
      Tab页的效果其实是和左边菜单息息相关的,首先还是看看Tab页效果的js引用。
       
      页面的html标签:
                 

       
      • 首页

      bootstrap-tab.js这个文件里面封装了addTabs方法

      var addTabs = function (options) {
        //var rand = Math.random().toString();
        //var id = rand.substring(rand.indexOf('.') + 1);
        var url = window.location.protocol + '//' + window.location.host;
        options.url = url + options.url;
        id = "tab_" + options.id;
        $(".active").removeClass("active");
        //如果TAB不存在,创建一个新的TAB
        if (!$("#" + id)[0]) {
          //固定TAB中IFRAME高度
          mainHeight = $(document.body).height() - 90;
          //创建新TAB的title
          title = '
    • ' + options.title; //是否允许关闭 if (options.close) { title += ' '; } title += '
    • '; //是否指定TAB内容 if (options.content) { content = '
      ' + options.content + '
      '; } else {//没有内容,使用IFRAME打开链接 content = '
      '; } //加入TABS $(".nav-tabs").append(title); $(".tab-content").append(content); } //激活TAB $("#tab_" + id).addClass('active'); $("#" + id).addClass("active"); }; var closeTab = function (id) { //如果关闭的是当前激活的TAB,激活他的前一个TAB if ($("li.active").attr('id') == "tab_" + id) { $("#tab_" + id).prev().addClass('active'); $("#" + id).prev().addClass('active'); } //关闭TAB $("#tab_" + id).remove(); $("#" + id).remove(); }; $(function () { mainHeight = $(document.body).height() - 45; $('.main-left,.main-right').height(mainHeight); $("[addtabs]").click(function () { addTabs({ id: $(this).attr("id"), title: $(this).attr('title'), close: true }); }); $(".nav-tabs").on("click", "[tabclose]", function (e) { id = $(this).attr("tabclose"); closeTab(id); }); });

      那么,在什么时候调用Addtabs方法呢?答案是注册菜单click事件的时候,这部分代码在前面sidebar-menu组件封装的时候就有,可以看看上面。

      以上就是bootstrap ace模板的菜单和Tab页效果的展示,总的来说,基本的功能具备了,但菜单的样式还有待调整,比如点击某个菜单之后,点击的菜单需要给一个选中的状态。如果你的项目也是用的bootstrap风格,研究下ace模板,可以使用起来试试。

      相关文章

      Bootstrap 5 轮播图实现自动播放 + 循环完毕后自动暂停

      如何正确引入 Bootstrap 日期选择器的 JS 与 CSS 文件

      如何在点击导航链接后自动关闭 Bootstrap 5 响应式汉堡菜单

      Vue Router 与 Bootstrap 折叠导航栏的兼容性解决方案

      Vue Router 与 Bootstrap 折叠导航栏冲突的解决方案

      java速学教程(入门到精通)
      java速学教程(入门到精通)

      java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

      下载

      相关标签:

      bootstrap

      本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

      上一篇:jQuery给元素添加样式的方法详解_jquery 下一篇:Underscore源码分析_javascript技巧

      热门AI工具

      更多
      DeepSeek
      DeepSeek

      幻方量化公司旗下的开源大模型平台

      AI 编程开发AI 聊天问答
      豆包大模型
      豆包大模型

      字节跳动自主研发的一系列大型语言模型

      AI 编程开发AI大模型
      通义千问
      通义千问

      阿里巴巴推出的全能AI助手

      AI 编程开发Agent智能体
      腾讯元宝
      腾讯元宝

      腾讯混元平台推出的AI助手

      文档处理AI 聊天问答
      文心一言
      文心一言

      文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

      AI 编程开发AI 文本写作
      讯飞写作
      讯飞写作

      基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

      AI 文本写作中文写作
      即梦AI
      即梦AI

      一站式AI创作平台,免费AI图片和视频生成。

      图片拼接
      ChatGPT
      ChatGPT

      最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

      AI 编程开发AI 文本写作
      智谱清言 - 免费全能的AI助手
      智谱清言 - 免费全能的AI助手

      智谱清言 - 免费全能的AI助手

      AI 编程开发Agent智能体

      相关专题

      更多
      Python 序列化
      Python 序列化

      本专题整合了python序列化、反序列化相关内容,阅读专题下面的文章了解更多详细内容。

      0

      2026.02.02

      AO3官网入口与中文阅读设置 AO3网页版使用与访问
      AO3官网入口与中文阅读设置 AO3网页版使用与访问

      本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

      91

      2026.02.02

      主流快递单号查询入口 实时物流进度一站式追踪专题
      主流快递单号查询入口 实时物流进度一站式追踪专题

      本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

      26

      2026.02.02

      Golang WebAssembly(WASM)开发入门
      Golang WebAssembly(WASM)开发入门

      本专题系统讲解 Golang 在 WebAssembly(WASM)开发中的实践方法,涵盖 WASM 基础原理、Go 编译到 WASM 的流程、与 JavaScript 的交互方式、性能与体积优化,以及典型应用场景(如前端计算、跨平台模块)。帮助开发者掌握 Go 在新一代 Web 技术栈中的应用能力。

      11

      2026.02.02

      PHP Swoole 高性能服务开发
      PHP Swoole 高性能服务开发

      本专题聚焦 PHP Swoole 扩展在高性能服务端开发中的应用,系统讲解协程模型、异步IO、TCP/HTTP/WebSocket服务器、进程与任务管理、常驻内存架构设计。通过实战案例,帮助开发者掌握 使用 PHP 构建高并发、低延迟服务端应用的工程化能力。

      5

      2026.02.02

      Java JNI 与本地代码交互实战
      Java JNI 与本地代码交互实战

      本专题系统讲解 Java 通过 JNI 调用 C/C++ 本地代码的核心机制,涵盖 JNI 基本原理、数据类型映射、内存管理、异常处理、性能优化策略以及典型应用场景(如高性能计算、底层库封装)。通过实战示例,帮助开发者掌握 Java 与本地代码混合开发的完整流程。

      5

      2026.02.02

      go语言 注释编码
      go语言 注释编码

      本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

      62

      2026.01.31

      go语言 math包
      go语言 math包

      本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

      55

      2026.01.31

      go语言输入函数
      go语言输入函数

      本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

      27

      2026.01.31

      热门下载

      更多
      网站特效
      /
      网站源码
      /
      网站素材
      /
      前端模板
      • [图片特效]时间轴图片切换代码
      • [表单按钮]jquery自动填充搜索框
      • [图片特效]swiper倾斜图片左右切换特效
      • [图片特效]jQuery Banner图片旋转切换代码
      • [表单按钮]css3实现3D登录表单 css3实现3D登录表单网页特效
      • [图片特效]jQuery选项卡切换图片异步加载代码
      • [表单按钮]jQuery Select下拉框美化插件
      • [图片特效]jquery橡皮擦工具图像擦除效果代码
      • [图片特效]jQ品牌logo列表选项卡切换 jQuery品牌logo列表选项卡切换
      • [表单按钮]jQuery启用禁用表单 jQuery启用禁用表单网页特效
      • [电商源码]openaishop
      • [其它模板]思翔企(事)业单位文件柜 build 20080313
      • [企业站源码]雅龙智能装备工业设备类WordPress主题1.0
      • [电商源码]威发卡自动发卡系统
      • [电商源码]卡密分发系统
      • [电商源码]中华陶瓷网
      • [电商源码]简洁粉色食品公司网站
      • [电商源码]极速网店系统
      • [电商源码]淘宝妈妈_淘客推广系统
      • [电商源码]积客B2SCMS商城系统
      • [网站素材]2026马年装饰合集矢量素材
      • [网站素材]红色浪漫情人节竖版海报PSD模板下载
      • [网站素材]创意文字情人节海报矢量模板
      • [网站素材]新中式水墨山水画矢量素材
      • [网站素材]美味披萨宣传INS海报模板设计下载
      • [网站素材]可爱民俗风彩色生肖马矢量插画
      • [网站素材]红色爱心情人节主题海报设计源文件下载
      • [网站素材]2026马年新年贺卡矢量模板
      • [网站素材]蓝色极简风格招聘海报设计下载
      • [网站素材]新春喜庆灯笼梅花挂饰矢量素材
      • [前端模板]驾照考试驾校HTML5网站模板
      • [前端模板]驾照培训服务机构宣传网站模板
      • [前端模板]HTML5房地产公司宣传网站模板
      • [前端模板]新鲜有机肉类宣传网站模板
      • [前端模板]响应式天气预报宣传网站模板
      • [前端模板]房屋建筑维修公司网站CSS模板
      • [前端模板]响应式志愿者服务网站模板
      • [前端模板]创意T恤打印店网站HTML5模板
      • [前端模板]网页开发岗位简历作品展示网页模板
      • [前端模板]响应式人力资源机构宣传网站模板

      相关下载

      更多
      php商城系统
      淘源码商城PHP淘宝查信誉
      PHP房产程序[BBWPS]
      PHP简约自动发卡平台个人版
      ERMEB域名PHP离线网络授权系统
      Difeye-敏捷的轻量级PHP框架
      大泉州汽车网PHP整站程序

      精品课程

      更多
      相关推荐
      /
      热门推荐
      /
      最新课程
      Bootstrap 5教程
      Bootstrap 5教程

      共46课时 | 3.2万人学习

      HTML+CSS基础与实战
      HTML+CSS基础与实战

      共132课时 | 10.1万人学习

      JS进阶与BootStrap学习
      JS进阶与BootStrap学习

      共39课时 | 3.2万人学习

      JavaScript ES5基础线上课程教学
      JavaScript ES5基础线上课程教学

      共6课时 | 11.2万人学习

      最新ThinkPHP 5.1全球首发视频教程(60天成就PHP大牛线上培训班课)
      最新ThinkPHP 5.1全球首发视频教程(60天成就PHP大牛线上培训班课)

      共79课时 | 152万人学习

      phpStudy极速入门视频教程
      phpStudy极速入门视频教程

      共6课时 | 53.5万人学习

      最新Python教程 从入门到精通
      最新Python教程 从入门到精通

      共4课时 | 22.4万人学习

      JavaScript ES5基础线上课程教学
      JavaScript ES5基础线上课程教学

      共6课时 | 11.2万人学习

      PHP新手语法线上课程教学
      PHP新手语法线上课程教学

      共13课时 | 0.9万人学习

      最新文章

      更多
      javascript运算符如何使用_逻辑与比较运算符有什么区别【教程】
      javascript this是什么_它的指向如何确定【教程】
      Jest框架如何测试javascript代码【教程】
      如何在 Express 中正确绑定类方法作为中间件以保持 this 上下文
      Next.js 字体导入导致 Hydration 错误的完整解决方案
      javascript 高阶函数是什么_有哪些常见例子【教程】
      javascript如何实现继承_ES5和ES6方式有何不同【教程】
      什么是javascript模块化开发【教程】
      Electron 应用中自定义字体加载失败的解决方案
      如何实现右对齐输入框中从左侧光标位置按 Delete 键删除最右侧字符
      关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
      php中文网:公益在线php培训,帮助PHP学习者快速成长!
      关注服务号

      微信扫码
      关注PHP中文网服务号

      技术交流群

      QQ扫码
      加入技术交流群

      PHP中文网订阅号
      每天精选资源文章推送

      Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

    • PHP学习

    • 技术支持

    • 返回顶部