国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開(kāi)發(fā) > JS > 正文

JS實(shí)現(xiàn)移動(dòng)端整屏滑動(dòng)的實(shí)例代碼

2024-05-06 16:40:50
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

基本思路:

1)檢測(cè)手指滑動(dòng)方向:獲取手指抬起時(shí)的位置,減去手指按下時(shí)的位置,得正即為向下滑動(dòng)了

2)手指抬起后,向?qū)?yīng)反向操作改變當(dāng)前頁(yè)的位置

具體代碼如下:

html

<div id="wrap">  <div id="page01" class="pages">第一屏</div>  <div id="page02" class="pages">第二屏</div>  <div id="page03" class="pages">第三屏</div>  <div id="page04" class="pages">第四屏</div></div><div id="dots">  <span class="now"></span><span class=""></span><span class=""></span><span class=""></span></div>

css

*{      margin:0;      padding:0;    }    body{      overflow: hidden;    }    #wrap > div{      width: 10rem;      position: absolute;      left: 0;      top: 0;      background: #fff;      transition: all 0.3s ease;    }    #dots{      position: fixed;      right: 5px;      top: 40%;      z-index: 9;    }    #dots span{      display: block;      height: 0.2rem;      width: 0.2rem;      border: 1px solid #000;      border-radius: 50%;      margin-bottom: 3px;    }    #dots .now{      background: #555;    }

js分為兩塊

第一,設(shè)置html標(biāo)簽的font-size,以便設(shè)置rem的基數(shù) (放在頁(yè)面頭部)

document.getElementsByTagName("html")[0].style.fontSize = window.innerWidth/10 + "px";

第二,具體的滑動(dòng)操作代碼

 window.onload = function(){      var oDiv = document.getElementById("wrap");      var aPages = oDiv.getElementsByClassName("pages");      var aDots = document.getElementById("dots").getElementsByTagName("span");      var winH = window.innerHeight;      var tTime = 1;      //設(shè)置每頁(yè)的高度和zindex值      for(var i=0; i<aPages.length; i++){        aPages[i].style.height = winH + "px";        aPages[i].style.zIndex = 1;      }      aPages[0].style.zIndex = 3;      aPages[1].style.zIndex = 2;      oDiv.style.height = winH + "px";      //手指拖動(dòng)事件(去除默認(rèn)動(dòng)作)      document.addEventListener("touchmove",function(e){        e.preventDefault();      });      var YStart = 0;      var iNow = 0;      //手指按下      oDiv.addEventListener("touchstart",function(e){        YStart = e.changedTouches[0].clientY;      });      //手指移動(dòng)      oDiv.addEventListener("touchmove",function(e){        disY = e.changedTouches[0].clientY-YStart; //向下滑正,向上滑負(fù)      });      //手指離開(kāi)      oDiv.addEventListener("touchend",function(e){        disY = e.changedTouches[0].clientY-YStart; //向下滑正,向上滑負(fù)        if(Math.abs(disY)>winH/20){ //只有當(dāng)滑動(dòng)距離大于了一定值得時(shí)候,才執(zhí)行切換          if(disY<0){            iNow++;            if(iNow>=aDots.length){              iNow = 0;            }            aPages[0].style.transform = "translateY("+ -winH +"px)";            doSlide();          }else{            iNow--;            if(iNow<0){              iNow = aDots.length-1;            }            aPages[0].style.transform = "translateY("+ winH +"px)";            doSlide("up");          }        }      });      function doSlide(upflag){        for(var i=0;i<aDots.length;i++){          aDots[i].className = "";        }        aDots[iNow].className = "now";        if(upflag){            //向上滑            aPages[3].style.zIndex = 2;            aPages[1].style.zIndex = 1;            oDiv.insertBefore(aPages[3],aPages[1]);            setTimeout(function(){              aPages[1].style.transform = "translateY(0px)";              aPages[1].style.zIndex = 2;              aPages[0].style.zIndex = 3;            },300)        }else{          setTimeout(function(){            aPages[0].style.transform = "translateY(0px)";            aPages[0].style.zIndex = 1;            aPages[1].style.zIndex = 3;            aPages[2].style.zIndex = 2;            oDiv.appendChild(aPages[0]);          },300)        }      }    }

好了,在給大家分享一段簡(jiǎn)單的代碼,JS實(shí)現(xiàn)移動(dòng)端整頁(yè)滑屏示,具體代碼如下所示:

<!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>移動(dòng)端整頁(yè)滑屏示例</title>    <style type="text/css">      * {        padding: 0;        margin: 0;        font-family: Verdana;      }      body,      html {        height: 100%;        background-color: #000000;      }      .wrap {        width: 100%;        height: 100%;        overflow: hidden;      }      .wrap2 {        width: 100%;        height: 1000%;        transition: 0.3s linear      }      .page {        width: 100%;        height: 10%      }      .page {        background-color: #fdfdfd;        font-size: 100px;        line-height: 400px;        text-align: center;        font-weight: bold;      }    </style>  </head>  <body>    <div class="wrap" id="wrap">      <div class="wrap2" id="wrap2">        <div class="page">1</div>        <div class="page" style="background-color:#dddddd;">2</div>        <div class="page">3</div>        <div class="page" style="background-color:#dddddd;">4</div>        <div class="page">5</div>        <div class="page" style="background-color:#dddddd;">6</div>      </div>    </div>    <script type="text/javascript">      //重要!禁止移動(dòng)端滑動(dòng)的默認(rèn)事件      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)'; //根據(jù)手指的位置移動(dòng)頁(yè)面        };        //touchEnd        var touchend = function(event) {          //位移小于+-50的不翻頁(yè)          if(moveY < -50) n++;          if(moveY > 50) n--;          //最后&最前頁(yè)控制          if(n < 0) n = 0;          if(n > len - 1) n = len - 1;          //重定位          box2.style.transform = 'translateY(' + (-n * 10) + '%)'; //根據(jù)百分比位置移動(dòng)頁(yè)面          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, //一共有幾頁(yè)        n: 0 //頁(yè)面一打開(kāi)默認(rèn)在第幾頁(yè)?第一頁(yè)就是0,第二頁(yè)就是1      });    </script>  </body></html>

總結(jié)

以上所述是小編給大家介紹的JS實(shí)現(xiàn)移動(dòng)端整屏滑動(dòng)的實(shí)例代碼,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到JavaScript/Ajax教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 响水县| 海林市| 闵行区| 多伦县| 沿河| 凤城市| 刚察县| 桃园市| 厦门市| 浮梁县| 昌吉市| 桐乡市| 三门峡市| 望江县| 吉安市| 隆尧县| 宁河县| 丹凤县| 莒南县| 剑川县| 江津市| 胶州市| 陇南市| 汝州市| 台北市| 湖南省| 潮州市| 吐鲁番市| 班戈县| 大丰市| 玛纳斯县| 延寿县| 沭阳县| 桂平市| 舞阳县| 新乡县| 莱阳市| 巫山县| 呼和浩特市| 普兰店市| 遵化市|