0

0

如何为导航菜单启用响应式滚动高亮效果(仅在屏幕宽度大于750px时生效)

碧海醫心

碧海醫心

发布时间:2026-02-07 22:03:58

|

881人浏览过

|

来源于php中文网

原创

如何为导航菜单启用响应式滚动高亮效果(仅在屏幕宽度大于750px时生效)

本文介绍如何实现导航标签栏的动态高亮滑动效果,并确保该功能仅在桌面端(屏幕宽度 > 750px)启用,通过监听 `resize` 事件实时响应窗口尺寸变化,避免因未刷新页面导致的响应失效问题。

要让导航菜单的滑动高亮效果(如 .active-highlight 动态跟随激活 Tab)智能适配设备断点,关键在于:不仅需在页面加载时判断屏幕尺寸,更需在窗口缩放过程中持续校验并启停逻辑。直接使用 $(document).width() 在 resize 中检测存在兼容性与时机问题;而 window.innerWidth 是更可靠、标准的视口宽度获取方式,且能实时反映当前浏览器窗口尺寸。

以下是优化后的完整实现方案:

DALL·E 2
DALL·E 2

OpenAI基于GPT-3模型开发的AI绘图生成工具,可以根据自然语言的描述创建逼真的图像和艺术。

下载

✅ 正确做法:基于 window.innerWidth 的动态启停控制

$(document).ready(function() {
  let isDesktopMode = window.innerWidth > 750;

  // 初始化高亮元素(仅在桌面模式下执行)
  function initHighlight() {
    if (!isDesktopMode) return;
    const navTabs = $('.nav-tabs');
    if (navTabs.find('.active-highlight').length === 0) {
      navTabs.prepend('
  • '); } } // 更新高亮位置(仅在桌面模式下执行) function updateHighlight(resize = false) { if (!isDesktopMode) return; const navTabs = $('.nav-tabs'); const activeTab = navTabs.find('.active'); if (!activeTab.length) return; const navPos = navTabs.offset(); const tabPos = activeTab.offset(); const highlight = navTabs.find('.active-highlight'); const left = tabPos.left - navPos.left; const top = tabPos.top - navPos.top; const width = activeTab.outerWidth(); const height = activeTab.outerHeight(); highlight.css({ 'transition': resize ? 'none' : 'all .5s ease', 'width': width + 'px', 'height': height + 'px', 'left': left + 'px', 'top': top + 'px' }); } // 页面加载时初始化 initHighlight(); updateHighlight(true); // 首次无过渡 // 监听窗口尺寸变化,动态切换模式并更新状态 $(window).on('resize', function() { const newMode = window.innerWidth > 750; if (newMode !== isDesktopMode) { isDesktopMode = newMode; if (isDesktopMode) { initHighlight(); updateHighlight(true); } else { // 移除高亮(可选:提升移动端性能/语义清晰) $('.nav-tabs .active-highlight').remove(); } } else if (isDesktopMode) { updateHighlight(); } }); // Tab 切换时更新高亮(仅桌面生效) $('[data-bs-toggle="tab"]').on('shown.bs.tab', function() { if (isDesktopMode) updateHighlight(); }); });

    ⚠️ 注意事项与最佳实践

    • 避免重复初始化:使用 isDesktopMode 标志位控制逻辑开关,防止在 resize 过程中反复创建 .active-highlight 元素;
    • 移动端优雅降级:当进入移动端(≤750px),主动移除高亮元素,既节省资源,也避免样式残留干扰;
    • 性能优化:resize 事件高频触发,此处未做防抖(debounce),因逻辑轻量;若项目复杂,建议添加 requestAnimationFrame 或节流处理;
    • CSS 补充建议:为确保 .active-highlight 在小屏下完全隐藏(即使 JS 未及时移除),可在 CSS 中追加:
      @media (max-width: 750px) {
        .nav-tabs > .active-highlight {
          display: none !important;
        }
      }

    该方案彻底解决了“仅刷新生效”的缺陷,实现了真正的响应式交互——无论用户是首次访问、横竖屏切换,还是拖拽浏览器窗口,高亮行为均能精准匹配当前设备视口,兼顾体验与健壮性。

    热门AI工具

    更多
    DeepSeek
    DeepSeek

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

    豆包大模型
    豆包大模型

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

    通义千问
    通义千问

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

    腾讯元宝
    腾讯元宝

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

    文心一言
    文心一言

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

    讯飞写作
    讯飞写作

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

    即梦AI
    即梦AI

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

    ChatGPT
    ChatGPT

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

    相关专题

    更多
    js正则表达式
    js正则表达式

    php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

    516

    2023.06.20

    js获取当前时间
    js获取当前时间

    JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

    307

    2023.07.28

    js 字符串转数组
    js 字符串转数组

    js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

    424

    2023.08.03

    js是什么意思
    js是什么意思

    JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

    5490

    2023.08.17

    js删除节点的方法
    js删除节点的方法

    js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

    484

    2023.09.01

    js截取字符串的方法
    js截取字符串的方法

    js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

    213

    2023.09.04

    Js中concat和push的区别
    Js中concat和push的区别

    Js中concat和push的区别:1、concat用于将两个或多个数组合并成一个新数组,并返回这个新数组,而push用于向数组的末尾添加一个或多个元素,并返回修改后的数组的新长度;2、concat不会修改原始数组,是创建新的数组,而push会修改原数组,将新元素添加到原数组的末尾等等。本专题为大家提供concat和push相关的文章、下载、课程内容,供大家免费下载体验。

    239

    2023.09.14

    js截取字符串的方法介绍
    js截取字符串的方法介绍

    JavaScript字符串截取方法,包括substring、slice、substr、charAt和split方法。这些方法可以根据具体需求,灵活地截取字符串的不同部分。在实际开发中,根据具体情况选择合适的方法进行字符串截取,能够提高代码的效率和可读性 。

    273

    2023.09.21

    Golang处理数据库错误教程合集
    Golang处理数据库错误教程合集

    本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

    39

    2026.02.06

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

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

    共14课时 | 0.8万人学习

    Bootstrap 5教程
    Bootstrap 5教程

    共46课时 | 3.2万人学习

    CSS教程
    CSS教程

    共754课时 | 28.6万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

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