本文介绍如何在页面初次加载(含 url 带 hash)和后续 hash 变更时,均能自动为指定元素添加 `.open` 类,实现锚点定位后的视觉反馈,解决仅监听 `hashchange` 事件导致的首次加载失效问题。
要让 jQuery 在页面首次加载时就响应 URL 中的 hash(例如直接访问 https://www.mypage/members#anchorX),仅依赖 hashchange 事件是不够的——因为该事件只在 hash 发生变化时触发,而页面初始加载时并无“变化”发生。
正确的做法是:将核心逻辑封装为独立函数,并在 DOM 就绪后立即执行一次,同时绑定到 hashchange 事件上。这样既覆盖了初始加载场景,也兼容后续手动跳转或浏览器前进/后退等动态 hash 更新。
以下是推荐的完整实现:
$(function() {
// 核心处理函数:根据当前 hash 添加 .open 类
function handleHash() {
const hash = window.location.hash;
if (hash && hash.length > 1) {
// 使用原生 hash 字符串(如 '#anchorX')直接作为 jQuery 选择器
// ✅ 更安全、更高效,避免 ID 转义与拼接风险
$(hash).next('div').addClass('open');
}
}
// 页面加载完成时立即执行(处理初始 hash)
handleHash();
// 同时监听 hash 变更(处理后续跳转)
$(window).on('hashchange', handleHash);
});? 关键优化说明:
? 补充建议:
通过这一设计,无论用户是直接访问带 hash 的链接,还是在页面内点击锚点跳转,目标内容区块都能即时获得 .open 样式(如红色文字、完全不透明),实现一致、可靠的用户体验。