JS监听滚动和id自动定位滚动
本文主要介绍原生JS进行滚动监听和id定位滚动,与效果锚点类似,适用于vue。
关键性代码如下:
varscroll=document.documentElement.scrollTop||document.body.scrollTop;//获取屏幕距离顶部的距离
.js//下述方法是引入mui+vue的案例,展示代码为methods里面的方法
init:function(){ doc.addEventListener("scroll",function(){//实时监听,如果是ios需要做300ms延迟,否则点击索引的时候,对象距离顶部的高度不够,会出现闪动的效果,体验感不佳 if(!noScroll){ varappealDo=vm.$el.querySelector("#appealDo").offsetTop-45;//获取#appealDo距离顶部的距离 varappealComm=vm.$el.querySelector("#appealComm").offsetTop-45;//获取#appealComm距离顶部的距离 varscrollTop=doc.body.scrollTop||doc.documentElement.scrollTop;//获取屏幕距离顶部的距离 if(scrollTop<=appealDo){ vm.activeIdx=0;//activeIdx是表示高亮,用作顶栏菜单 }elseif(scrollTop>appealDo&&scrollTop<=appealComm){ vm.activeIdx=1; }elseif(scrollTop>appealComm){ vm.activeIdx=2; } } noScroll=false; }); }, toggleTypes:function(idx){ noScroll=true; if(vm.activeIdx!=idx){ if(idx===0){ doc.body.scrollTop=0; doc.documentElement.scrollTop=0; }elseif(idx===1){ vm.$nextTick(function(){ doTop=vm.$el.querySelector("#appealDo").offsetTop-45; doc.body.scrollTop=doTop; doc.documentElement.scrollTop=doTop; }); }else{ vm.$nextTick(function(){ doTop=vm.$el.querySelector("#appealComm").offsetTop-45; doc.body.scrollTop=doTop; doc.documentElement.scrollTop=doTop; }); } vm.activeIdx=idx; } },
在VUE脚手架的项目里面可以这样操作,下述案例实现的是做高度监听控制顶部菜单的透明度变化
mounted(){ window.addEventListener('scroll',this.menu) }, methods:{ menu(){ this.scroll=document.documentElement.scrollTop||document.body.scrollTop; varopacity=this.scroll/44; if(opacity<=1){ this.$nextTick(()=>{ this.opacity=opacity }); }else{ this.opacity=1 } } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。