导航全局滑动JavaScript
/// <summary> /// 前往某个指定ID的锚点 /// </summary> /// <param name="id">锚点ID</param> /// <param name="cutHeight">稍上或稍下的高度值</param> function goTo(id, cutHeight) { //IE6下会读不到值 // alert("ID=" + id + "的标签与顶部的实际高度距离为:" + document.getElementById(id).offsetTop); var h = document.getElementById(id).offsetTop; if (h == 0) h = 20300; scroll(0, h - cutHeight); } //↓↓↓↓↓导航全局滑动↓↓↓↓↓/////start var oldCurrent = 0; var oldtop; var sindex = 0; function movebox(id) { sindex++; var daohang = document.getElementById(id); var objleft = getObUpperLeft(daohang, 1); var objtop = getObUpperLeft(daohang, 2); if (sindex == 1) oldtop = objtop; var cha = getPageScroll2() - oldtop; if (cha <= oldCurrent) { if (cha > 0) { daohang.style.display = "Block"; daohang.style.position = "fixed"; daohang.style.top = "0px"; try { ////判断IE6.0不同写法 var browser = navigator.appName; var b_version = navigator.appVersion; var version = b_version.split(";"); var trim_Version = version[1].replace(/[ ]/g, ""); if (browser == "Microsoft Internet Explorer" && trim_Version == "MSIE6.0") { daohang.style.position = "absolute"; daohang.style.left = objleft + "px"; daohang.style.top = getPageScroll2() + "px"; } } catch (e) { } } else { daohang.style.position = "static"; } } else { daohang.style.display = "none"; } oldCurrent = cha; } window.onscroll = function() { movebox("daohang"); } //获取对象坐标 function getObUpperLeft(obj, type) { var curLeft = curTop = 0; if (obj.offsetParent) { curLeft = obj.offsetLeft; curTop = obj.offsetTop; while (obj = obj.offsetParent) { curLeft += obj.offsetLeft; curTop += obj.offsetTop; } } if (type == 1) return curLeft; else if (type == 2) return curTop; } //获取浏览器滚动条高度 function getPageScroll2() { var yScroll; if (self.pageYOffset) { yScroll = self.pageYOffset; } else if (document.documentElement && document.documentElement.scrollTop) { yScroll = document.documentElement.scrollTop; } else if (document.body) { yScroll = document.body.scrollTop; } return yScroll; }
标签:
JS 导航 全局滑动
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Sdcb Chats 技术博客:数据库 ID 选型的曲折之路 - 从 Guid 到自增 ID,再到
· 语音处理 开源项目 EchoSharp
· 《HelloGitHub》第 106 期
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 使用 Dify + LLM 构建精确任务处理应用