移动端整页滑屏示例(上下滑动整屏)demo效果示例(整理)

简介: 移动端整页滑屏示例(上下滑动整屏)demo效果示例(整理)
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8"/>
        <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=0" />
        <meta name="format-detection" content="telephone=no" />
        <meta content="yes" name="mobile-web-app-capable">
        <meta content="yes" name="apple-mobile-web-app-capable" />
        <meta http-equiv="Cache-Control" content="no-siteapp" />
        <title>移动端整页滑屏示例</title>
        <style type="text/css">
          *{padding:0;margin:0}
      body,html{height:100%;background-color:#000}
      .wrap{width:100%;height:100%;overflow:hidden}
      .wrap2{width:100%;height:1000%;transition:.3s linear}
      .page{width:100%;height:10%;background-color:#fdfdfd;font-size:100px;line-height:400px;text-align:center;font-weight:700}
        </style>
    </head>
    <body>
        <div class="wrap" id="wrap">
            <div class="wrap2" id="wrap2">
                <div class="page">我是第一屏内容</div>
                <div class="page" style="background-color:#ccc;">我是第二屏内容</div>
                <div class="page">我是第三屏内容</div>
                <div class="page" style="background-color:#ccc;">我是第四屏内容</div>
                <div class="page">我是第五屏内容</div>
                <div class="page" style="background-color:#ccc;">我是第六屏内容</div>
            </div>
        </div>
        <script type="text/javascript">
            //重要!禁止移动端滑动的默认事件
            document.body.addEventListener('touchmove', function(event) {
                event = event ? event : window.event;
                if(event.preventDefault) {
                    event.preventDefault()
                } else {
                    event.returnValue = false
                }
            }, false)
            var pages = function(obj) {
                var box = document.getElementById(obj.wrap);
                var box2 = document.getElementById(obj.wrap2);
                var len = obj.len;
                var n = obj.n;
                var startY, moveY, cliH;
                //获取屏幕高度
                var getH = function() {
                    cliH = document.body.clientHeight
                };
                getH();
                window.addEventListener('resize', getH, false);
                //touchStart
                var touchstart = function(event) {
                    if(!event.touches.length) {
                        return;
                    }
                    startY = event.touches[0].pageY;
                    moveY = 0;
                };
                //touchMove
                var touchmove = function(event) {
                    if(!event.touches.length) {
                        return;
                    }
                    moveY = event.touches[0].pageY - startY;
                    box2.style.transform = 'translateY(' + (-n * cliH + moveY) + 'px)'; //根据手指的位置移动页面
                };
                //touchEnd
                var touchend = function(event) {
                    //位移小于+-50的不翻页
                    if(moveY < -50) n++;
                    if(moveY > 50) n--;
                    //最后&最前页控制
                    if(n < 0) n = 0;
                    if(n > len - 1) n = len - 1;
                    //重定位
                    box2.style.transform = 'translateY(' + (-n * 10) + '%)'; //根据百分比位置移动页面
                    console.log(n)
                };
                //touch事件绑定
                box.addEventListener("touchstart", function(event) {
                    touchstart(event)
                }, false);
                box.addEventListener("touchmove", function(event) {
                    touchmove(event)
                }, false);
                box.addEventListener("touchend", function(event) {
                    touchend(event)
                }, false);
            };
            pages({
                wrap: 'wrap', //.wrap的id
                wrap2: 'wrap2', //.wrap2的id
                len: 6, //一共有几页
                n: 0 //页面一打开默认在第几页?第一页就是0,第二页就是1
            });
        </script>
    </body>
</html>

备注:需在手机端滑动查看效果

F12选择手机端查看

感谢您的支持

相关文章
uniapp轮播带查看大图效果demo示例、带数字的轮播(整理)
uniapp轮播带查看大图效果demo示例、带数字的轮播(整理)
|
6天前
|
移动开发 JavaScript
简单介绍下阿里云的H5滑动验证+H5示例源码
简单介绍下阿里云的H5滑动验证+H5示例源码
54 0
|
6天前
|
Java 定位技术 Android开发
【Android App】集成腾讯地图显示位置和地图面板讲解及实战(附源码和演示 超详细必看)
【Android App】集成腾讯地图显示位置和地图面板讲解及实战(附源码和演示 超详细必看)
95 1
移动端可拖拽效果demo效果示例(整理)
移动端可拖拽效果demo效果示例(整理)
移动端touch事件demo效果示例(整理)
移动端touch事件demo效果示例(整理)
jq点击导航页面滑动到对应内容demo效果示例(整理)
jq点击导航页面滑动到对应内容demo效果示例(整理)
仿百度导航跟随效果demo效果示例(整理)
仿百度导航跟随效果demo效果示例(整理)
uniapp动态获取中间内容高度demo效果(整理)
uniapp动态获取中间内容高度demo效果(整理)
uniapp显示富文本效果demo(整理)
uniapp显示富文本效果demo(整理)
|
8月前
|
小程序 定位技术
uniapp小程序打开地图选择位置demo效果wx.chooseLocation(整理)
uniapp小程序打开地图选择位置demo效果wx.chooseLocation(整理)