移动端首屏整屏翻动

英雄联盟周边商城服饰上新时,有做一个移动端,首页翻屏,但是后面都是滚动效果的
touch事件分三步。touchstart,touchmove,touchend

<div class="g-wrap">
    <div class="top">
     //需要翻屏的首页
    </div>
    <div class="g-main">
        <a name="content"></a>
        //滚动的内页
    </div>
</div>
<script>
    var annzmy= {
        init: function () {
            var winH = $(window).height();//获取页面高度
            var obj_= $('.top');//整屏部分
            var scllObj = $('.g-wrap');//整个页面
            var sY,sMove,sEnd,contrast;
            //整屏部分绑定触摸touchstart事件
            obj_.bind('touchstart',function(e){
                var evt = e ? e:window.event;
                evt.preventDefault();//阻止元素默认事件冒泡
                var touch = evt.touches[0];//获取第一个触点
                sY = touch.clientY;//页面触点的Y坐标
                scllObj.css({
                    'transition':'none'
                })
            });
            //滑动事件,页面滑动的效果
            obj_.bind('touchmove',function(e) {
                var evt = e ? e:window.event;
                evt.preventDefault();
                var touch = evt.touches[0];
                sMove = touch.clientY;//获取滑动时的Y坐标
                scllObj.css({
                    'transform':'translateY(' + (sMove - sY) + 'px)',//滑动此时的坐标-开始触摸的坐标=回正所需位移
                    'transition':'none'
                })
            });
            //触摸结束
            obj_.bind('touchend',function(e){
                var evt = e ? e:window.event;
                var touch = evt.changedTouches[0];
                sEnd = touch.clientY;
                contrast =  sEnd - sY;//结束时的坐标-开始时的坐标
                if(contrast > -120){
                    scllObj.css({
                        'transform':'translateY(0px)',
                        'transition':'.3s'
                    })
                }else{
                    scllObj.css({
                        'transform':'translateY(-100vh)',//滑动查过一定距离,翻屏
                        'transition':'.3s',
                        'margin-bottom': '-100vh'
                    })
                }
            });

            //内容滑动
            $('.g-main').on('touchstart',function (e) {
                var evt = e ? e:window.event;
                var touch = evt.touches[0];
                sY = touch.clientY
            });
            $('.g-main').on('touchmove',function (e) {
                var evt = e ? e:window.event;
                var touch = evt.touches[0];
                sMove = touch.clientY;
                var movePx = sMove - sY;//移动的距离,大于零代表向下
                var contTop = $('a[name=content]').offset().top;//此页面顶点距离窗口顶部的距离
               
                if(contTop >= 0 && movePx > 10){
                    evt.preventDefault();
                    scllObj.css({
                        'transform':'translateY(-' + (winH - movePx) + 'px)',
                        'transition':'none'
                    })
                }
            });
            $('.g-main').on('touchend',function (e) {
                var evt = e ? e : window.event;
                var touch = evt.changedTouches[0];
                sEnd = touch.clientY;
                var movePx = sEnd - sY;
                var contTop = $('a[name=content]').offset().top;
                if (contTop >= 0 && movePx > 120) {
                    scllObj.css({
                        'transform': 'translateY(0px)',
                        'transition': '.3s'
                    })
                } else {
                    scllObj.css({
                        'transform': 'translateY(-100vh)',
                        'transition': '.3s'
                    })
                }
            });
        }
    };
    $(function () { annzmy.init(); });
</script>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • mobileHack 这里收集了许多移动端上遇到的各种坑与相对解决方案 工具类网站 HTML5 与 CSS3 技术...
    Zoemings阅读 6,575评论 0 12
  • 在前端的移动Web开发中,有一部分事件只在移动端产生,如触摸相关的事件。接下来给大家简单总结一下移动端的事件。 1...
    IT老马阅读 5,126评论 1 20
  • 一、 基础事件 1.click事件 单击事件,类似于PC端的click,但在移动端中,连续click的触发有200...
    满天繁星_28c5阅读 671评论 0 0
  • _________________________________________________________...
    fastwe阅读 1,322评论 0 0
  • 一、 基础事件 1.click事件 单击事件,类似于PC端的click,但在移动端中,连续click的触发有200...
    致自己_cb38阅读 541评论 0 0