用JQuery做一个简单的分屏滚动效果《一》

浏览: 4,189次 日期:2018年06月24日 19:13:48 作者:青格勒

平常会遇到这样的需求,网站整屏滚动效果。

 

效果如下图,红色为浏览器窗口,其他为每一个块儿,当我们使用鼠标的滚轮的时候会上下切换。

 

到这里咱们还需要一个东西,鼠标滚轮时间,还好有个插件帮咱们包装好了鼠标滚轮时间相关的参数

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>
    <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整屏滚动效果》,当然咱们也可以加个按钮来上下滚动,这个我会在往后的文章中写。

 

效果可以看 -》 点击这里看demo

 

文章链接:http://cenggel.com/js/108.html

版权声明:文章《用JQuery做一个简单的分屏滚动效果《一》》由青格勒编写,转载请带上文章链接。

本章内容纯属乱讲,如有雷同,纯属巧合。如有借鉴之处已表明出处。

点击任意位置关闭窗口,感谢您的支持。


打赏规则 - 为了避免对于打赏模式产生误解,说明一下几点内容:

  • 1.打赏纯粹自愿,金额不限,别太多,1块就行;
  • 2.打赏不能作为解答疑问的理由;
  • 3.打赏不能帮你做毕业设计或论文;
  • 4.打赏不能帮你做工作中的项目;
  • 5.打赏就是这不能那不能,只是单纯打赏而已。
  • 5.最后谢谢支持。
关闭
相关文章

发表评论

邮箱地址不会被公开。 必填项已用*标注