一、科普时间

hash

hash 属性是一个可读可写的字符串,该字符串是 URL 的锚部分(从 # 号开始的部分)。

location.hash=anchorname。

锚点

锚点是网页制作中超级链接的一种,又叫命名锚记。命名锚记像一个迅速定位器一样,是一种页面内的超级链接

二、锚点简单的栗子

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>伪锚点</title>
<style>
.anchor1, .anchor2{width:100px;height:100px;margin-top:2000px;margin-bottom:2000px;}
.anchor1{background:red;}
.anchor2{background:green;}
</style>
</head>
<body>
<p>
<a href="#anchor1">锚点1</a>
</p>
<p>
<a href="#anchor2">锚点2</a>
</p>
<div id="anchor1" class="anchor1">
锚点1
</div> <div id="anchor2" class="anchor2">
锚点2
</div>
</body>
</html>

解析

 访问该页面的地址:http://127.0.0.1/anchor.html(我是在本地服务器上测试的)

 点击a链接锚点1,则页面会直接跳到红色的div(锚点1),同时,浏览器地址改变为http://127.0.0.1/anchor.html#anchor1

 虽然可以直接定位到制定的位置,但是效果很差,没有平缓的过渡效果。

三、改进过渡效果

1)前期理论准备

 既然hash值是对应锚点的id值,那如果改为js动态获取hash值,然后再根据hash值获得dom对象。最后,用js进行平缓过渡。

 基于这个思路,就必须要求hash的取名有独特性,不能跟页面中的任何一个id一致,否则会触发浏览器默认的锚点定位行为。



2)确定特殊hash命名

 hash命名直接取特殊的前缀:w_,比如锚点1对应的hash值为w_anchor1

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>伪锚点</title>
<style>
.anchor1, .anchor2{width:100px;height:100px;}
.anchor1{background:red;}
.anchor2{background:green;}
.spacing1, .spacing2{height:200px;}
.spacing1{background:yellow;}
.spacing2{background:gray;}
</style>
</head>
<body>
<p>
<a href="#w_anchor1">锚点1</a>
</p>
<p>
<a href="#w_anchor2">锚点2</a>
</p>
<p class="spacing1">间隔1</p>
<p class="spacing2">间隔2</p>
<p class="spacing1">间隔3</p>
<p class="spacing2">间隔4</p>
<p class="spacing1">间隔5</p>
<p class="spacing2">间隔6</p>
<p class="spacing1">间隔7</p>
<p class="spacing2">间隔8</p> <div id="anchor1" class="anchor1">锚点1</div> <p class="spacing1">间隔1</p>
<p class="spacing2">间隔2</p>
<p class="spacing1">间隔3</p>
<p class="spacing2">间隔4</p>
<p class="spacing1">间隔5</p>
<p class="spacing2">间隔6</p>
<p class="spacing1">间隔7</p>
<p class="spacing2">间隔8</p> <div id="anchor2" class="anchor2">锚点2</div> <p class="spacing1">间隔1</p>
<p class="spacing2">间隔2</p>
<p class="spacing1">间隔3</p>
<p class="spacing2">间隔4</p>
<p class="spacing1">间隔5</p>
<p class="spacing2">间隔6</p>
<p class="spacing1">间隔7</p>
<p class="spacing2">间隔8</p>
</body>
</html>

3)编写读取特殊hasn值的方法以及缓动方法(本示例不考虑兼容性)

(function(window, undefined){
// 监听页面加载完成后,检查是否需要定位锚点
window.onload = function(){
scrollToAnchor();
}; // 监听地址栏url的hash值改变时,检查是否需要定位锚点
window.onhashchange = function(){
scrollToAnchor();
}; // 滚动到自定义的伪锚点
function scrollToAnchor(){
var hash = getHash(), // 获取url的hash值
anchor = getAnchor(hash), // 获取伪锚点的id
anchorDom, // 伪锚点dom对象
anchorScrollTop; // 伪锚点距离页面顶部的距离 // 如果不存在伪锚点,则直接结束
if(anchor.length < 1){
return;
} anchorDom = getDom(anchor);
anchorScrollTop = anchorDom.offsetTop; animationToAnchor(document.body.scrollTop, anchorScrollTop);
} /*
@function 滚动到指定位置方法
@param startNum {int} -- 开始位置
@param stopNum {int} -- 结束位置
*/
function animationToAnchor(startNum, stopNum){
var nowNum = startNum + 10; // 步进为10 if(nowNum > stopNum){
nowNum = stopNum;
} // 缓动方法
window.requestAnimationFrame(function(){
document.body.scrollTop = nowNum; // 当前示例页面,滚动条在body,所以滚动body // 滚动到预定位置则结束
if(nowNum == stopNum){
return;
} animationToAnchor(nowNum, stopNum); // 只要还符合缓动条件,则递归调用
});
} // 获取锚点id
function getAnchor(str){
return checkAnchor(str) ? str.split("w_")[1] : "";
} // 判断是否为特殊的hash值,也即是否为伪锚点
function checkAnchor(str){
return str.indexOf("w_") == 0 ? true : false;
} // 获取hash值
function getHash(){
return window.location.hash.substring(1);
} // 获取dom对象
function getDom(id){
return document.getElementById(id);
}
})(window);

在线演示:https://wall-wxk.github.io/blogDemo/anchor/anchor.html

最后,附上完整示例源码

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>伪锚点</title>
<style>
.anchor1, .anchor2{width:100px;height:100px;}
.anchor1{background:red;}
.anchor2{background:green;}
.spacing1, .spacing2{height:200px;}
.spacing1{background:yellow;}
.spacing2{background:gray;}
</style>
</head>
<body>
<p>
<a href="#w_anchor1">锚点1</a>
</p>
<p>
<a href="#w_anchor2">锚点2</a>
</p>
<p class="spacing1">间隔1</p>
<p class="spacing2">间隔2</p>
<p class="spacing1">间隔3</p>
<p class="spacing2">间隔4</p>
<p class="spacing1">间隔5</p>
<p class="spacing2">间隔6</p>
<p class="spacing1">间隔7</p>
<p class="spacing2">间隔8</p> <div id="anchor1" class="anchor1">锚点1</div> <p class="spacing1">间隔1</p>
<p class="spacing2">间隔2</p>
<p class="spacing1">间隔3</p>
<p class="spacing2">间隔4</p>
<p class="spacing1">间隔5</p>
<p class="spacing2">间隔6</p>
<p class="spacing1">间隔7</p>
<p class="spacing2">间隔8</p> <div id="anchor2" class="anchor2">锚点2</div> <p class="spacing1">间隔1</p>
<p class="spacing2">间隔2</p>
<p class="spacing1">间隔3</p>
<p class="spacing2">间隔4</p>
<p class="spacing1">间隔5</p>
<p class="spacing2">间隔6</p>
<p class="spacing1">间隔7</p>
<p class="spacing2">间隔8</p>
<script>
(function(window, undefined){
// 监听页面加载完成后,检查是否需要定位锚点
window.onload = function(){
scrollToAnchor();
}; // 监听地址栏url的hash值改变时,检查是否需要定位锚点
window.onhashchange = function(){
scrollToAnchor();
}; // 滚动到自定义的伪锚点
function scrollToAnchor(){
var hash = getHash(), // 获取url的hash值
anchor = getAnchor(hash), // 获取伪锚点的id
anchorDom, // 伪锚点dom对象
anchorScrollTop; // 伪锚点距离页面顶部的距离 // 如果不存在伪锚点,则直接结束
if(anchor.length < 1){
return;
} anchorDom = getDom(anchor);
anchorScrollTop = anchorDom.offsetTop; animationToAnchor(document.body.scrollTop, anchorScrollTop);
} /*
@function 滚动到指定位置方法
@param startNum {int} -- 开始位置
@param stopNum {int} -- 结束位置
*/
function animationToAnchor(startNum, stopNum){
var nowNum = startNum + 10; // 步进为10 if(nowNum > stopNum){
nowNum = stopNum;
} // 缓动方法
window.requestAnimationFrame(function(){
document.body.scrollTop = nowNum; // 当前示例页面,滚动条在body,所以滚动body // 滚动到预定位置则结束
if(nowNum == stopNum){
return;
} animationToAnchor(nowNum, stopNum); // 只要还符合缓动条件,则递归调用
});
} // 获取锚点id
function getAnchor(str){
return checkAnchor(str) ? str.split("w_")[1] : "";
} // 判断是否为特殊的hash值,也即是否为伪锚点
function checkAnchor(str){
return str.indexOf("w_") == 0 ? true : false;
} // 获取hash值
function getHash(){
return window.location.hash.substring(1);
} // 获取dom对象
function getDom(id){
return document.getElementById(id);
}
})(window);
</script>
</body>
</html>



阅读原文:www.jianshu.com/p/aefa75666905

hash实现锚点平滑滚动定位的更多相关文章

  1. 仿微信未读RecyclerView平滑滚动定位效果

    效果图有红点的地方表示有未读消息,依次双击首页图标定位,然后定位到某个未读在手动下滑一点距离在次点击定位效果 用过 RecyclerView 的人都知道,自带有几个滚动到item下标的方法,但是不靠谱 ...

  2. JQuery实现锚点平滑滚动

    一般使用锚点来跳转到页面指定位置的时候,会生硬地立即跳转到指定位置,但是有些时候我们想要平滑地过渡到指定的位置,那么可以使用JQuery简单的实现这个效果: 比如,这里我们将通过点击<a> ...

  3. vue2.0模拟锚点实现定位平滑滚动

    vue2.0模拟锚点实现定位平滑滚动 效果为点击哪一个标题,平滑滚动到具体的详情. 如果是传统项目,这个效果就非常简单.但是放到 Vue 中,就有两大难题: 1. 在没有 jQuery 的 anima ...

  4. jQuery实现锚点平滑定位

    一般的锚点,就是点击一个按钮或者其他元素可以实现定位效果,当然可以使用锚点实现,但是这个不够美观,没有平滑的动画过渡效果,下面就通过代码实例介绍一下利用jquery实现平滑的定位效果. <!DO ...

  5. JQuery简单实现锚点链接的平滑滚动

    在平时的项目中,我们经常需要一些特效链接,如果使效果进一步加强,我们可以使点击锚点链接平滑滚动到锚点,下面就来给大家讲解下如何使用jQuery来实现.   一般使用锚点来跳转到页面指定位置的时候,会生 ...

  6. 【前端】jQuery实现锚点向下平滑滚动特效

    jQuery实现锚点向下平滑滚动特效 实现效果: 实现原理: 使用jQuery animate()方法实现页面平滑滚动特效 $('html, body').animate({scrollTop: $( ...

  7. 使用jquery animate实现锚点慢慢平滑滚动效果

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. jQuery实现页面内锚点平滑跳转

    平时我们做导航滚动到内容都是通过锚点来做,刷的一下就直接跳到内容了,没有一丝的滚动效果,而且 url 链接最后会有“小尾巴”,就像#keleyi,今天我就介绍一款 jquery 做的滚动的特效,既可以 ...

  9. js平滑滚动到顶部,底部,指定地方

    [原文链接] 采用锚点进行页面中的跳转的确很方便,但是要想增加网页的效果,可以使用jquery中的animate,实现滚动的一个动作,慢慢的滚动到你想跳转到的位置,从而看起来会非常高大上. [示例演示 ...

随机推荐

  1. 用CQRS+ES实现DDD

    用CQRS+ES实现DDD 这篇文章应该算是对前三篇的一个补充,在写之前说个题外话,有园友评论这是在用三层架构在写DDD,我的个人理解DDD是一种设计思想,跟具体用什么架构应该没有什么关系,DDD也需 ...

  2. IT行业新名词--透明手机/OCR(光学字符识别)/夹背电池

    透明手机 机身设计的一大关键部分是可替换玻璃的使用,利用导电技术,在看不到线路的环境下,让LED发光. 这样的玻璃内含液晶分子,对于内容的显示则是通过电流对分子的刺激来实现.当手机断电后,分子位置会随 ...

  3. C# & WPF 随手小记之一 ——初探async await 实现多线程处理

    嗯...我也是在园子待了不短时间的人了,一直以来汲取着园友的知识,感觉需要回馈什么. 于是以后有空我都会把一些小技巧小知识写下来,有时候可能会很短甚至很简单,但希望能帮到大家咯. 第一篇文章来说说as ...

  4. 如何用CSC.exe来编译Visual C#的代码文件

    原文:如何用CSC.exe来编译Visual C#的代码文件 C#的编译过程      如何用CSC.exe来编译Visual C#的代码文件   Csc.exe 编译器的位置路径:C:\Window ...

  5. MVC无刷新分页

    MVC无刷新分页(即局部刷新,带搜索,页数选择,排序功能)   我查看了很多网站,大部分评论分页都是局部刷新的,可大部分电商商品展示分页都是有刷新页面的,于是我便做了一个商品展示无刷新分页的例子.接下 ...

  6. gradle测试与线上打包

    首先,第一反应理所当然的是profile : <?xml version="1.0" encoding="UTF-8"?> <beans xm ...

  7. linux之stat函数解析

    [lingyun@localhost stat_1]$ vim stat.c  + stat.c                                                     ...

  8. Linux 下安装 SVN服务器

    前段时间换了一个新项目组.过去发现居然SVN都没有.代码都是手动对比存档.当时就蛋疼了.这他妈也太苦逼了.话不多说,要来测试服务器地址.开工了.由于服务器不能连接外网. 1.先下载安装包.本次安装不结 ...

  9. ToolBox Analysis & Design

    话说小菜过做已近3年,虽出身PHP后项目大多涉及.net,系统也做得比较繁杂,从常见的CMS,企业OA,ERP,也涉及到电商系统的开发定制,爬虫,工具不一而足,其中web系统居多. 由于表现良好,时常 ...

  10. Winform系列

    小菜学习编程-Winform系列(初学者)   前言 记得上次写<小菜的程序员道路(二)>,这篇文章的时候说过,要把工作以来整理的编程知识分享给大家,因为这半年来的工作实在是忙,现在也在忙 ...