前言

当页面最上部有顶部菜单是,使用锚点跳转的方法很容易挡住想要呈现的内容(如下图技能两个字被挡住了一半),为避免出现这样的问题,故滚动到指定元素使用用JS的方法来实现。

目录

  1. 使用的API简介
  2. 初版(第一版)
  3. 优化(第二版)
  4. 继续优化(第三版 引入tween.js库)

正文

1  使用的API简介

  • document.querySelectorAll

  • preventDefault

  • currentTarget

  • getAttribute

  • document.querySelector

  • offsetTop
  • window.scrollTo
  • window.scrollY

  • setInterval

  • window.clearInterval

2  初版(第一版)

  • 代码及思路如下:

    //1 获取所有的a标签
    let aTags=document.querySelectorAll("nav.menu ul li a")
    //console.log(aTags)
    //2 遍历a标签并点击标签滚动到指定元素位置
    for(let i=;i<=aTags.length;i++){
    aTags[i].onclick=function(x){
    x.preventDefault(); //阻止a标签默认的跳转
    //console.log(x.currentTarget);
    let a=x.currentTarget;
    let href=a.getAttribute("href"); //找到href中的内容,如果href中时一个锚点则返回#siteSkill
    //console.log(href);
    let element=document.querySelector(href); //找到内容中的锚点对应ID的标签,如对应的锚点名为#siteSkill,则返回<section class=​"skills" id=​"siteWorks">​…​</section>​
    //console.log(element);
    let top=element.offsetTop; //获取元素到页面最顶点的高度(不会随着页面滚动变化的高度)
    //console.log(top);
    window.scrollTo(,top-);
    }
    }
  • 效果图如下
  • 这样能准确的达到想要的地方并且也不会内容也不会被挡住,但是,也存在一些缺点,比如跳转太生硬,中间没有过渡,影响用户体验。

3  优化(第二版)

  • 优化后代码如下:

    //1 获取所有的a标签
    let aTags=document.querySelectorAll("nav.menu ul li a")
    //console.log(aTags)
    //2 遍历a标签并点击标签跳到指定元素位置
    for(let i=;i<=aTags.length;i++){
    aTags[i].onclick=function(x){
    x.preventDefault(); //阻止a标签默认的跳
    let a=x.currentTarget;
    let href=a.getAttribute("href"); //找到href中的内容,如果href中时一个锚点则返回#siteSkill
    let element=document.querySelector(href); //找到内容中的锚点对应ID的标签,如对应的锚点名为#siteSkill,则返回<section class=​"skills" id=​"siteWorks">​…​</section>​
    let top=element.offsetTop;
    let n=; //动的次数
    let t=/n; //多久动一次
    let currentTop=window.scrollY; //所在的位置
    let targetTop=top-; //目标位置
    var s=(targetTop-currentTop)/n; //每次动的距离
    let i=;
    let id=setInterval(()=>{
    if(i===n){
    window.clearInterval(id);
    return;
    } //当i=n时停止动画
    i=i+
    window.scrollTo(,currentTop+s*i) },t)
    }
    }
  • 优化后有跳转动画,但是依然还有缺点,比如:定义的是时间一致,所以跳转到距离TOP不同位置的地方速度不一致。看起来依然生硬不自然

4  继续优化(第三版 引入tween.js库)

  • 再次优化后的代码

    //1 引入tween.js库
    <script src='https://cdnjs.cloudflare.com/ajax/libs/tween.js/17.2.0/Tween.min.js'></script>
    <script> //2 获取所有的a标签 let aTags=document.querySelectorAll("nav.menu ul li a");
    function animate(time){
    requestAnimationFrame(animate);
    TWEEN.update(time);
    }
    requestAnimationFrame(animate); //3 遍历a标签并在点击标签时滚动到指定元素的位置
    for(let i=;i<=aTags.length;i++){
    aTags[i].onclick=function(x){
    x.preventDefault(); //阻止a标签默认的跳
    let a=x.currentTarget;
    let href=a.getAttribute("href"); //找到href中的内容,如果href中时一个锚点则返回#siteSkill
    let element=document.querySelector(href); //找到内容中的锚点对应ID的标签,如对应的锚点名为#siteSkill,则返回<section class=​"skills" id=​"siteWorks">​…​</section>​
    let top=element.offsetTop;
    let currentTop=window.scrollY; //所在的位置
    let targetTop=top-; //目标位
    let s=targetTop-currentTop; //所在到目标的高度差
    let t=Math.abs((s/)*) //Math.abs方法保证时间为正值不为负数。ps:Math的首字母需要大写!!!
    var coords={y:currentTop}; //y为所在位置
    if(t>=){t=} //如果时间最大为500,不超过500
    var tween=new TWEEN.Tween(coords)
    .to({y:targetTop},t) //y为到达目标位置,时间
    .easing(TWEEN.Easing.Quadratic.In)
    .onUpdate(function(){
    window.scroll(,coords.y)
    })
    .start();
    }
    } </script>

使用JS方法使页面滚动到指定元素+优化+API介绍(动画)的更多相关文章

  1. jquery页面滚动到指定id

    //jquery页面滚动到指定id  $body = (window.opera) ? (document.compatMode == "CSS1Compat" ? $('html ...

  2. 滚动到指定元素的id处+当元素出现在浏览器显示区域就会自动加载

    //滚动到指定元素的id处 如:$("#Exam82") function Jump() { var scroll_offset = $("#Exam82"). ...

  3. js 页面滚动到指定位置

    当页面的长度比较长时,如果进行刷新页面,我们希望能够在刷新完成页面之后,能够停留在当前位置,而不是从头再手动滚动到当前位置. 那么这样的效果如何实现呢?下面开始简单描写(由于博客园不支持效果展示,所以 ...

  4. aos.js超赞页面滚动元素动画jQuery动画库

    插件描述:aos.js 是一款效果超赞的页面滚动元素动画jQuery动画库插件.该动画库可以在页面滚动时提供28种不同的元素动画效果,以及多种easing效果.在页面往回滚动时,元素会恢复到原来的状态 ...

  5. 页面滚动图片等元素动态加载插件jquery.scrollLoading.js

    如果一个网页很长,那么该页面的加载时间也会相应的较长.而这里给大家介绍的这个jQuery插件scrollLoading的作用则是,对页面元素进行动态加载,通俗的说就是滚到哪就加载到哪,屏幕以下看不见的 ...

  6. 使用js方法将table表格中指定列指定行中相同内容的单元格进行合并操作。

    前言 使用js方法对html中的table表格进行单元格的行列合并操作. 网上执行此操作的实例方法有很多,但根据实际业务的区别,大多不适用. 所以在网上各位大神写的方法的基础上进行了部分修改以适合自己 ...

  7. 每天一点点之 uni-app 框架开发 - 页面滚动到指定位置

    项目需求:在页面中,不管位于何处,点击评论按钮页面滚动到对应到位置 实现思路如下: uni.createSelectorQuery().select(".comment").bou ...

  8. 微信小程序页面滚动到指定位置

    页面上有一个元素或者组件,id 为 comment 则: var me = this; var query = wx.createSelectorQuery().in(me); query.selec ...

  9. js方法的命名不能使用表单元素的名称或ID

    今天在写页面的时候,遇到一个关于js方法的命名问题,先看下代码: 表单元素如下: <select name="isCulture" onchange="isCult ...

随机推荐

  1. TP5异常处理

    TP5异常处理 标签(空格分隔): php, thinkphp5 自定义异常处理 namespace app\common\exception; use think\Exception; class ...

  2. inotify-tools+rsync实时同步文件安装和配置

    服务器A:论坛的主服务器,运行DZ X2论坛程序;服务器B:论坛从服务器,需要把X2的图片附件和MySQL数据实时从A主服务器实时同步到B服务器.MySQL同步设置会在下一编中说到.以下是用于实时同步 ...

  3. 敬请关注 Linr 公众号

  4. 移动端 | Vue.js对比微信小程序基础语法

    (1)vue 自定义组件与父组件的通信,props:[abb],可以看成自组建的一个自定义属性 (2)vue 模版语法{{}} 只能是在DOM中插入,<div>{{acc}}</di ...

  5. jmeter的认识

    jmeter JMeter是Apache组织开发的开源项目,设计之初是用于做性能测试的,同时它在实现对各种接口的调用方面做的比较成熟,因此,常被用做接口功能测试和性能测试. 它能够很好的支持各种常见接 ...

  6. deploy sql clr

    1, create strong signed key file 2, create asymmetric key

  7. CorelDRAW 2018新增功能介绍

    2018年4月11日,CorelDRAW 2018正式对外发布,最新版设计软件包已经过全面更新,是近几年来发行的最强大版本,可协助绘图专业人士将创意转换为令人惊艳的专业视觉设计.CorelDRAW 2 ...

  8. ZBrush中平滑笔刷介绍

    平滑笔刷在ZBrush®中的使用颇多,它可以在ZBrush®模型的多层细分下工作,并且能够控制对模型的平滑效果,而且还能将模型的细节完整保留.默认情况下,按住Shift键就会切换到平滑笔刷,根据调整不 ...

  9. Ibatis在运行期得到可执行到sql

    环境:oracle-11g ,ibatis-2.0 ,java-1.7 最近因为有个需要是在程序中得到ibatis到sql字符串,即通过以下的ibatis配置得到sql语句 <select id ...

  10. ARM - Linux嵌入式C/C++各种资料分享【更新日期:2012/04/24】

    http://blog.csdn.net/shuxiao9058/article/details/6786868 由于115网盘取消大众分享功能,因此不能继续分享下载链接.更新资料将在本人分享空间转存 ...