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
}
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。