mobile 轮播图

小圆点逻辑(排他)

1. 统一给所有 span 元素加 class="";

2. 切换到谁,谁的 class="active";

  • 移动端轮播图
  • <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
    <title>移动端轮播图</title> <style type="text/css">
    * {
    padding: 0;
    margin: 0;
    } a {
    text-decoration: none;
    } ul,
    ol {
    list-style: none;
    } input {
    outline: none;
    } img {
    display: block;
    } html,
    body {
    height: 100%;
    overflow: hidden;
    } #wrap {
    width: 100%;
    height: 100%; background-color: #96b377;
    } /**** ****/
    #wrap {
    position: relative;
    } #wrap #ul_list {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    width: 500%;
    } #wrap #ul_list>li {
    float: left;
    } #wrap #ul_list>li>a>img{
    width: 100%;
    } /**** 小圆点 ****/
    #ol_list {
    position: absolute;
    bottom: 10px;
    right: 10px;
    width: 75px;
    display: flex;
    justify-content: space-between;
    } #ol_list li {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: gray;
    } #ol_list li.active {
    background-color: deeppink;
    }
    </style>
    </head> <body> <!-- 模拟手机屏幕 -->
    <section id="wrap">
    <ul id="ul_list">
    <li>
    <a href="javascript:;"><img src="./img/Deadpool.jpg"/></a>
    </li> <li>
    <a href="javascript:;"><img src="./img/Groot.jpg"/></a>
    </li> <li>
    <a href="javascript:;"><img src="./img/Hock.jpg"/></a>
    </li> <li>
    <a href="javascript:;"><img src="./img/RocketRaccoon.jpg"/></a>
    </li> <li>
    <a href="javascript:;"><img src="./img/SpiderMan.jpg"/></a>
    </li>
    </ul> <ol id="ol_list">
    <li data-pindex="0" class="active"></li>
    <li data-pindex="1"></li>
    <li data-pindex="2"></li>
    <li data-pindex="3"></li>
    <li data-pindex="4"></li>
    </ol>
    </section> <!-- javascript 代码 -->
    <script type="text/javascript">
    // 取消默认行为
    document.addEventListener("touchstart", function(e){
    e.preventDefault();
    }, false); // 点透处理 var clientWidth = document.documentElement.clientWidth;
    // 适配
    (function(){ /* 1. 创建 style 标签 */
    var styleNode = document.createElement("style"); /* 2. 给 style 标签添加内容 (屏幕分份, 大多数公司 16 份) */
    styleNode.innerHTML = "html {"+
    "font-size:"+clientWidth/16+"px !important"+
    "}"; /* IPhone 6 的 font-size: 23.4375px */ /* 3. 把 style 标签追加到 head 标签里 */
    document.head.appendChild(styleNode);
    }()); var wrap = document.getElementById("wrap");
    var ulList = document.getElementById("ul_list");
    var olList = document.getElementById("ol_list"); var lis = document.querySelectorAll("#ul_list>li");
    var points = document.querySelectorAll("#ol_list>li"); window.onload = function(){
    var styleNode = document.createElement("style");
    styleNode.innerHTML = "#ul_list {width:"+lis.length+"00%;}";
    styleNode.innerHTML += "#ul_list>li {width:"+100/lis.length+"%;}";
    document.head.appendChild(styleNode); styleNode.innerHTML += "#wrap {height:"+lis[0].offsetHeight+"px;}";
    }; var oldUlX = 0;
    var oldTouchX = 0;
    var curIndex = 0;
    wrap.addEventListener("touchstart", function(e){
    var touch = e.changedTouches; oldTouchX = touch[0].clientX;
    oldUlX = ulList.offsetLeft;
    },false); wrap.addEventListener("touchmove", function(e){
    var touch = e.changedTouches; var newTouchX = touch[0].clientX;
    var newUlX = oldUlX + (newTouchX - oldTouchX); if(newUlX > 0){
    newUlX = 0;
    }else if(newUlX < -ulList.offsetWidth+clientWidth){
    newUlX = -ulList.offsetWidth+clientWidth;
    } ulList.style.left = newUlX + "px";
    },false); wrap.addEventListener("touchend", function(){
    curIndex = Math.round(-ulList.offsetLeft/clientWidth); ulList.style.left = -curIndex*clientWidth + "px"; for(var i=0; i<points.length; i++){
    points[i].className = "";
    };
    points[curIndex].className = "active";
    },false); olList.addEventListener("touchstart", function(e){
    touch = e.changedTouches;
    e.stopPropagation();
    ele = touch[0].target;
    if(ele.nodeName == "LI"){
    for(var i=0; i<points.length; i++){
    points[i].className = "";
    };
    ele.className = "active"; curIndex = +ele.dataset.pindex;
    ulList.style.left = -curIndex*clientWidth + "px";
    };
    }, false);
    </script>
    </body>
    </html>

mobile_轮播图_style_left 版本的更多相关文章

  1. mobile_轮播图_transform 版本_transform 读写二合一

    轮播图_transform 版本 关键点: 2D 变换 transform 不会改变 元素 在 文档流 中的位置 定位 position 会改变 元素 在 文档流 中的位置 语句解析太快,使用 set ...

  2. 轮播图采用js、jquery实现无缝滚动和非无缝滚动的四种案例实现,兼容ie低版本浏览器

    项目源代码下载地址:轮播图 以下为项目实现效果:(由于gif太大,所以只上传一张图片,但效果完全能实现,经测试,在ie各版本浏览器及chrome,firefox等浏览器中均能实现效果,可以实现点击切换 ...

  3. iOS swift版本无限滚动轮播图

    之前写过oc版本的无限滚动轮播图,现在来一个swift版本全部使用snapKit布局,数字还是pageConrrol样式可选 enum typeStyle: Int { case pageContro ...

  4. jquery版本轮播图(es5版本,兼容高)

    优势:基于es5,兼容高.切换动画css配置,轻量,不包含多余代码,可扩展性很高,多个轮播图不会冲突,可配置独有namespace 注: 1.项目需要所写,所以只写了页码的切换,未写上一页下一页按钮, ...

  5. ViewPager轮播图

    LoopViewPagerLayout无限轮播 项目地址:https://github.com/why168/LoopViewPagerLayout 支持三种动画: 支持修改轮播的速度: 支持修改滑动 ...

  6. (新手向)基于Bootstrap的简单轮播图的手机实现

    个人电脑里存了不少适合手机欣赏的图片,但是放手机里看是件很占据资源的事.鉴于家里有一台电脑经常开着,正好用来做家庭局域网共享,于是笔者就设想通过一种比较简单环保的思路.通过手机访问电脑内的图片. 首先 ...

  7. swift-自定义无限轮播图

    一  前言 1.之前一直在用OC编程,最近才开始接触使用swift就发现使用OC越来越不习惯,感觉已经爱上了swift. 2.这个自定义轮播图只是对之前OC版本进行了翻译,欢迎指正. 3.我决定一步步 ...

  8. 原生JS面向对象思想封装轮播图组件

    原生JS面向对象思想封装轮播图组件 在前端页面开发过程中,页面中的轮播图特效很常见,因此我就想封装一个自己的原生JS的轮播图组件.有了这个需求就开始着手准备了,代码当然是以简洁为目标,轮播图的各个功能 ...

  9. ⒃bootstrap组件 轮播图 基础案例

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. java集合分割

    java集合分割成等份的小集合: private <T> List<List<T>> getSubList(List list,int len) { if(list ...

  2. JavaScript对象 Object类型基础

    前言 JavaScript 对象是整个语言学习的一个难点.本文主要带大家入门学习Object知识 对象定义 javascript的基本数据类型包括undefined.null.boolean.stri ...

  3. [Luogu P1144]最短路计数

    emmmm这个题看起来非常复杂,实际上仔细一分析发现到一个点最短路的个数就是所有前驱最短路个数之和.如果在图上表示也就是以1为根的bfs搜索树,一个点的最短路个数等于每一个能够向它扩展的所有点的最短路 ...

  4. [再寄小读者之数学篇](2014-06-20 Beta 函数)

    令 $\dps{B(m,n)=\sum_{k=0}^n C_n^k \cfrac{(-1)^k}{m+k+1}}$, $m,n\in\bbN^+$. (1) 证明 $B(m,n)=B(n,m)$; ( ...

  5. [物理学与PDEs]第2章习题5 正应力的平均值

    设流场中流体的应力张量为 ${\bf P}=(p_{ij})$. 试证明: 在以某点为中心, $r$ 为半径的球面 $S_r$ 上的法向应力分量的平均值, 在 $r\to 0$ 时的极限为该点正应力的 ...

  6. 浏览器录宏重放软件-iMacros

    iMacros https://imacros.net/ iMacros v12 Now Available The world's most popular web automation, data ...

  7. DUMP4 企业级电商项目 —— 对接支付宝扫码支付

    延展 <谈谈微信支付曝出的漏洞> [联调 DEMO下载地址]https://docs.open.alipay.com/194/105201/ [内置 一份 说明文档可做参考] [impor ...

  8. 有趣的若干个AI项目

    一.遗传算法跑贪吃蛇 1.下载processing,下载地址是:https://processing.org/download ,直接解压打开即可. 2.下载SnakeAI源码,下载地址是:https ...

  9. mysql 分库分表 ~ 柔性事务

    一 定义 TCC方案是可能是目前最火的一种柔性事务方案二 具体 内容 TCC=try(预设)-confrim(应用确认)-canal(回滚取消)三 目的 解决跨服务调用场景下的分布式事务问题,避免使用 ...

  10. R leaflet

    setRepositories()#1 chooseCRANmirror()#2 ibrary(leaflet)#学习地址:http://rstudio.github.io/leaflet/marke ...