zoukankan      html  css  js  c++  java
  • 移动端轮播图实例

    移动端轮播图

    采用手机端页面自适应解决方案—rem布局

    <!doctype html>
    <html lang="en">
    <head>
    	<meta charset="UTF-8" />
    	<meta name="viewport" content="width=device-width,user-scalable=no">
    	<title>移动端轮播图--cck</title>
    <script type="text/javascript">
    	// 手机端页面自适应解决方案—rem布局
    	(function (doc, win) {
            var docEl = doc.documentElement,
                resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',
                recalc = function () {
                    var clientWidth = docEl.clientWidth;
                    docEl.style.fontSize = clientWidth / 15 + 'px';
                };
    
            if (!doc.addEventListener) return;
            win.addEventListener(resizeEvt, recalc, false);
            doc.addEventListener('DOMContentLoaded', recalc, false);
        })(document, window);
    
    	// 阻止pc和浏览器默认行为。
    	document.addEventListener('touchstart',function(ev){
    		ev.preventDefault();
    	});
    </script>
    <style>
    body{
    	margin: 0;
    }
    .wrap{
    	height: 8.4rem;
    	position: relative;
    }
    .list{
    	padding: 0;
    	margin: 0;
    	400%;
    	position: absolute;
    	top: 0;
    	left: 0;
    	list-style: none;
    }
    .list li{
    	float: left;
    	 15rem;
    }
    .list img{
    	 15rem;
    	display: block;
    }
    nav{
    	 15rem;
    	height: 10px;
    	position: absolute;
    	bottom: 10px;
    	z-index: 1;
    	text-align:center;
    }
    nav a{
    	10px;
    	height: 10px;
    	display: inline-block;
    	background: red;
    	border-radius:50%;
    	vertical-align:top;
    }
    nav a.active{
    	background:#fff;
    }
    
    </style>
    </head>
    <body>
    	<section class="wrap">
    		<ul class="list">
    			<li>
    				<img src="http://img1.3lian.com/2015/a1/14/d/151.jpg" alt="" />
    			</li>
    			<li>
    				<img src="http://photos.tuchong.com/110168/f/2034247.jpg" alt="" />
    			</li>
    			<li>
    				<img src="http://img1.3lian.com/2015/a1/129/d/193.jpg" alt="" />
    			</li>
    			<li>
    				<img src="http://img.kutoo8.com//upload/image/78018037/201305280911_960x540.jpg" alt="" />
    			</li>
    		</ul>
    		<nav>
    			<a href="javascript:;" class="active"></a>
    			<a href="javascript:;"></a>
    			<a href="javascript:;"></a>
    			<a href="javascript:;"></a>
    		</nav>
    	</section>
    <script type="text/javascript">
    
    	var wrap = document.querySelector('.wrap'),
    		list = document.querySelector('.list'),
    		a = document.querySelectorAll('a');
    		disX = 0, // 按下的坐标
    		listL = 0, // 当前按下的list的left值
    		w = wrap.clientWidth, // 一张图片的宽度
    		len = 0,
    		n = 0; // 默认第一个小点为白色
    
    	list.innerHTML += list.innerHTML;  // 将list复制一份
    	len = list.children.length; // list节点数量的长度
    	list.style.width = w * len +'px';
    
    
    	list.addEventListener('touchstart', start);
    	list.addEventListener('touchmove', move);
    	list.addEventListener('touchend', end);
    
    	function start (ev) {
    		var e = ev.changedTouches[0]; // changedTouches  为涉及当前事件的手指的一个列表
    
    		list.style.transition = 'none';
    		disX = e.pageX; // e.pageX——手指所按位置相对整个页面的坐标
    
    		/*
    			手指按下时,判断是第几张图片,若为第一张,则快速拉到第五张上;若为最后一张张,则快速拉到第四张上
    		*/
    
    		var num = Math.round( list.offsetLeft / w );
    		console.log(num)
    		if(num == 0) {
    			num = a.length;
    			list.style.left = -num * w + 'px';
    		}
    
    		if(-num == len-1) {
    			num = a.length - 1;
    			list.style.left = -num * w + 'px';
    		}		
    
    		listL = this.offsetLeft;
    	}
    
    	function move (ev) {
    		var e = ev.changedTouches[0];
    		list.style.left = (e.pageX - disX) + listL +'px';
    	}
    
    	function end (ev) {
    		var num = Math.round( list.offsetLeft / w ); // 当前需要显示的那一张图片的索引
    
    		list.style.transition = '.5s';
    		list.style.left = num * w +'px';
    
    		a[n].className = '';
    		a[-num % a.length].className = 'active';
    		n = -num % a.length;
    	}
    
    </script>
    </body>
    </html>
    
  • 相关阅读:
    40种网页常用小技巧(javascript)
    伸缩效果
    震动的超链
    一个模仿图片透明渐变做的表格颜色渐变效果
    荧 光 效 果
    用LoadRunner编写socket应用的测试脚本
    突发奇想写的一篇小科幻(如果可以叫做科幻的话)
    《软件性能测试过程详解与案例剖析》一书在Chinapub上8月份的销售排名持续上升
    建立高效的测试团队
    探索性测试(Exploratory Testing)概述
  • 原文地址:https://www.cnblogs.com/cckui/p/7731835.html
Copyright © 2011-2022 走看看