Layui实现导航栏点击高亮效果——ChatGPT提供功能代码

2023-05-2112:25:34WEB前端开发Comments1,602 views字数 1237阅读模式

OneNav后台使用了Layui组件,因此这个方法适用于所有使用Layui组件的场合。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/40977.html

Layui实现导航栏点击高亮效果——ChatGPT提供功能代码文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/40977.html

Layui中导航栏点击高亮

这是OneNav中原始的导航栏代码,使用的a标签进行链接跳转,每次点击的时候都会跳转到新的页面。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/40977.html

<ul class="layui-nav layui-nav-tree"  lay-filter="test">
        <li class="layui-nav-item layui-nav-itemed">
          <a class="" href="javascript:;">链接管理</a>
          <dl class="layui-nav-child">
            <dd><a href="/index.php?c=admin&page=link_list">我的链接</a></dd>
            <dd><a href="/index.php?c=admin&page=add_link">添加链接</a></dd>
            <dd><a href="/index.php?c=admin&page=imp_link">书签导入</a></dd>
            <dd><a href="/index.php?c=admin&page=setting/share">书签分享</a></dd>
          </dl>
        </li>
    </ul>

Layui中,如果要实现某个菜单高亮,只需要加上layui-this这个类即可。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/40977.html

于是我将上述代码给到了ChatGPT,并告诉他点击高亮只需要添加现有的layui-this类,最终给出的代码如下:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/40977.html

<script>
  $(document).ready(function() {
    // 获取当前页面的 URL
    var currentUrl = window.location.href;

    // 遍历导航栏菜单的子菜单项
    $('.layui-nav-child dd a').each(function() {
      var $this = $(this);
      var linkUrl = $this.attr('href');

      // 如果子菜单项的链接与当前页面的 URL 匹配,则为该子菜单项添加 'layui-this' 类
      if (currentUrl.indexOf(linkUrl) !== -1) {
        // 移除其他菜单项的 'layui-this' 类
        $('.layui-nav-child dd').removeClass('layui-this');

        // 为匹配的子菜单项添加 'layui-this' 类
        $this.parent().addClass('layui-this');

        // 结束遍历
        return false;
      }
    });
  });
</script>

这段代码首先在文档加载完成后获取当前页面的 URL。然后,它遍历所有导航栏菜单的子菜单项,检查子菜单项的链接是否与当前页面的 URL 匹配。如果匹配,它将移除其他子菜单项的 'layui-this' 类,然后为匹配的子菜单项添加 'layui-this' 类。这样,当页面加载时,相应的菜单项将会被高亮显示。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/40977.html

xiaoz未做任何修改,直接添加到js中亲测可用,下方是实现后的效果。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/40977.html

Layui实现导航栏点击高亮效果——ChatGPT提供功能代码文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/40977.html

  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/gcs/40977.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定