首页 / JQUERY / 用JQuery做一个分屏滚动效果
用JQuery做一个分屏滚动效果
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了用JQuery做一个分屏滚动效果,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2286字,纯文字阅读大概需要4分钟。
内容图文
平常会遇到这样的需求,网站整屏滚动效果。效果如下图,红色为浏览器窗口,其他为每一个块儿,当我们使用鼠标的滚轮的时候会上下切换。
到这里咱们还需要一个东西,鼠标滚轮时间,还好有个插件帮咱们包装好了鼠标滚轮时间相关的参数
jquery.mousewheel.min.js
是个很出色的鼠标滚轮事件的插件,今天咱们就是用这个来写一个效果吧。
第一步、引入必要的插件和库
<script type="text/javascript" src="js/jquery-1.12.0.min.js"></script>
<script type="text/javascript" src="js/jquery.mousewheel.min.js"></script>
第二步、写好你的HTML和CSS
这里给body进行了position:relative的定位,然后再给id=main定位position:absolute,然后使用JQ控制
<div id="main">
<div class="mainlist mainlist0">青格勒</div>(www.gendan5.com
)
<div class="mainlist mainlist1">前端博客</div>
<div class="mainlist mainlist2">cenggel.com</div>
<div class="mainlist mainlist3">写一个</div>
<div class="mainlist mainlist4">整屏滚动效果</div>
<div class="mainlist mainlist5">开始!</div>
</div>
<style>
body{ position:relative; overflow:hidden; height:100%;}
#main{ position:absolute; top:0; left:0; width:100%; font-size:120px; color:#000; text-align:center; line-height:100%;}
.mainlist0{ background:#f6303d;}
.mainlist1{ background:#515151;}
.mainlist2{ background:#009f95;}
.mainlist3{ background:#333333;}
.mainlist4{ background:rosybrown;}
.mainlist5{ background:palegoldenrod;}
</style>
第三部、mousewheel.js简单介绍
在mousewheel里面有个参数为:event.deltaY,这个主要是获取鼠标滚轮是网上滚动还是往下滚动的。
event.deltaY(1、-1)
-1:为鼠标往下滚动
1:位鼠标网上滚轮
第四步、逻辑
因为咱们一般浏览网站的时候都是直接按住滚轮去操作,一般人的手指经过一次滚轮所触发的event为10左右,所以每一次触发滚动的数字为7比较合适。
每次触发滚轮的时候都记一次数,当触发的数量达到7的时候,整屏滚动就走一次,就这么简单。
下面直接贴代码吧:
<script type="text/javascript">
var winup = 0,//向上触发次数
windown = 0,//向下触发次数
num = 0;//当前页面位置
function fun1(){
//获取屏幕高度
winhei = $(window).height();
$(‘.mainlist,body‘).height(winhei)
}
fun1();
$(window).resize(function(){
//每当屏幕大小改变时计算一次
fun1();
});
$(‘#main‘).on(‘mousewheel‘, function(event) {
//鼠标滚轮触发
var mouseNum = event.deltaY;
if (mouseNum == 1){
//向上的时候触发
winup++;
windown = 0;
if(winup == 7){
winup=0;
if (num > 0){
num--;
$(‘#main‘).stop(false,true).animate({‘top‘: -(winhei*num) + ‘px‘},500);
};
};
}else{
//向下的时候触发
windown++;
winup=0;
if(windown == 7){
windown=0;
if (num<($(‘.mainlist‘).length - 1)){
num++;
$(‘#main‘).stop(false,true).animate({‘top‘: -(winhei*num) + ‘px‘},500);
};
};
};
});
</script>
这次就做一个比较简单的《JQuery整屏滚动效果》,当然咱们也可以加个按钮来上下滚动,这个我会在往后的文章中写。
原文:https://blog.51cto.com/14513127/2434949
内容总结
以上是互联网集市为您收集整理的用JQuery做一个分屏滚动效果全部内容,希望文章能够帮你解决用JQuery做一个分屏滚动效果所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。