自己写了一个javascript的可循环轮播图,支持手机滑动,不过代码着实小白,全局变量,函数调用满天飞,研究别的代码规范好的轮播图插件,表示看得懂但是写不出。。

HTML:

<div id="main" >
    <!--轮播图片或背景-->
    <div class="bigbox">
        <ul id="listCont">
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
            <li>5</li>
       </ul>
    </div>
</div>
<!--页数按钮-->
<div id="pageBtn">
    <a class="active">one</a>
    <a >two</a>
    <a >three</a>
    <a >four</a>
    <a >five</a>
</div>
<!--前后按钮-->
<div id="pnBtn">
    <a class="prev" > < <span></span></a>
    <a class="next" > > <span></span></a>
</div>

JS:

document.addEventListener('touchmove', function(event) {
    event.preventDefault();
 }, false);
//touchstart事件
function touchstartFunc(evt) {
    try {
        //evt.preventDefault(); //阻止触摸时浏览器的缩放、滚动条滚动等
        var touch = evt.touches[0]; //获取第一个触点
        var x = Number(touch.pageX); //页面触点X坐标
         var y = Number(touch.pageY); //页面触点Y坐标
         //记录触点初始位置
        startX = x;
        startY = y;
    } catch (e) {
        alert('touchstartFunc:' + e.message);
    }
}

//touchmove事件,这个事件无法获取坐标
function touchMoveFunc(evt) {
    //touchstartFunc(evt);
    try {
         //evt.preventDefault(); //阻止触摸时浏览器的缩放、滚动条滚动等
        var touch = evt.touches[0]; //获取第一个触点
        var x = Number(touch.pageX); //页面触点X坐标
        var y = Number(touch.pageY); //页面触点Y坐标
        //document.getElementById("main").innerHTML = "原:"+startY+" "+"现:"+y;
        //判断滑动方向
        if (x - startX > 50) {
            swipeRight();
           //alert("向右划");
        } else if(x - startX < -50){
            swipeLeft();
       }
    } catch (e) {
        alert('touchMoveFunc:' + e.message);
    }
}

//touchend事件
function touchEndFunc(evt) {
    try {
        //evt.preventDefault(); //阻止触摸时浏览器的缩放、滚动条滚动等
    } catch (e) {
        alert('touchEndFunc:' + e.message);
    }
}

document.getElementById("main").addEventListener('touchstart', touchstartFunc, false);
document.getElementById("main").addEventListener('touchmove', touchMoveFunc, false);
document.getElementById("main").addEventListener('touchend', touchEndFunc, false);

//页数按钮
var pageBtn = document.getElementById("pageBtn");
var pageList = document.getElementById("pageBtn").getElementsByTagName("a");

//前后按钮
var pnBtn = document.getElementById("pnBtn");
var pnList = document.getElementById("pnBtn").getElementsByTagName("a");
var prev = getByClass("prev","a",pnBtn);
var next = getByClass("next","a",pnBtn);

//轮播内容
var main = document.getElementById("main");//main content
var list = document.getElementById("main").getElementsByTagName('li');
var listCont = document.getElementById("listCont");//轮播列表
del_ff(listCont);
var count = list.length;
var listWidth = main.offsetWidth;
listCont.style.marginLeft = -listWidth + "px";

//将first子元素复制到列表尾,last复制到列表头
var f = listCont.firstChild.cloneNode(true);
var l = listCont.lastChild.cloneNode(true);
listCont.appendChild(f);
listCont.insertBefore(l,listCont.firstChild);

// main.addClass("trans");
main.className = "trans";
var time = setInterval("turn(-2)",5000);

//getElementsByClass
function getByClass(classname, tagname, parent){
    var result=[],
   _array=parent.getElementsByTagName(tagname);
    for(var i=0,j=_array.length;i<j;i++){
        if((new RegExp("(?:^|\\s+)"+classname+"(?:\\s+|$)")).test(_array[i].className)){
            result.push(_array[i]);
        }
    }
    return result;
}

//解决FF和chrome下把换行也当作子元素的bug
function del_ff(elem){
    var elem_child = elem.childNodes;
    for(var i=0; i<elem_child.length;i++){
        if(elem_child[i].nodeName == "#text" && !/\s/.test(elem_child.nodeValue)) {
            elem.removeChild(elem_child[i]);
        }
    }
}

//自适应宽度
for(var i=0;i<list.length;i++){
    list[i].index = i;
    list[i].style.width = listWidth+'px';
}

//turn
var timer = null;
function turn(dir){

    var flag = Math.abs(parseInt(listCont.style.marginLeft))/main.offsetWidth;

    if(dir == -1){ //前一张
        if(flag == 0){//flag = 0,在第一张并且要到前一张
            var tim = null;
            flag = list.length-3;
            listCont.className = "";
            tim = setTimeout(function(){
                listCont.style.marginLeft = -(flag+1)*listWidth + "px";
            },0)
        }else if(flag>0){
            flag--;
            }
       }else if(dir == -2){ //后一张
           if (flag < list.length-1 ) {
           flag++;
       }else{
           var tim = null;
           flag = 2;
           listCont.className = "";
           tim = setTimeout(function(){
               listCont.style.marginLeft = -listWidth + "px";
           },0)
        }
    }else{
         flag = dir;
}

clearTimeout(timer);
timer = setTimeout(function(){
    listCont.className = "trans";
    listCont.style.marginLeft = -flag*listWidth + "px";
},100)

//按钮激活
for(var i=0 ;i<pageList.length;i++){
    var index = flag;
    pageList[i].className=" ";
    if(index == 0) index = 5;
    else if(index == 6) index = 1;
    pageList[index-1].className="active";
}


}//turn end

//点击按钮翻页
for(var i=0 ;i<pageList.length;i++){
    pageList[i].index = i+1;
    pageList[i].onclick = function(){
        clearInterval(time);
        turn(this.index);
        time = setInterval("turn(-2)",5000);
    }
}

//前后按钮翻页
prev[0].onclick = function(){
    swipeRight();
}
next[0].onclick = function(){
    swipeLeft();
}

//右划 == 前一张
function swipeRight(){
    clearInterval(time);
    var dir = -1;
    turn(dir);
    time = setInterval("turn(-2)",5000);
}

//左划 == 下一张
function swipeLeft(){
    clearInterval(time);
    var dir = -2;
    turn(dir);
    time = setInterval("turn(-2)",5000);
}

js 自适应手机电脑 轮播图的更多相关文章

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

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

  2. 基于js的自适应、多样式轮播图插件(兼容IE8+、FF、chrome等主流浏览器)

    插件github地址:https://github.com/pomelott/slider-plug_in 使用方式: slider plug-in 左右滑动的自适应.多样式全能插件.多次调用时只需传 ...

  3. 原生js实现响应式轮播图,支持电脑端点击切图,手机端滑动切图

    轮播图的实现原理并不难,但是步骤有些繁琐.最近练习了一个轮播图,大部分是跟着网上的教程写的,然后自己做了一点兼容ie8的修改,加了点击切换图片的特效和手机端的滑动特效,让这个轮播图可以在响应式的网站中 ...

  4. js原生代码实现轮播图案例

    一.轮播图是现在网站网页上最常见的效果之一,对于轮播图的功能,要求不同,效果也不同! 我们见过很多通过不同的方式,实现这一效果,但是有很多比较麻烦,而且不容易理解,兼容性也不好. 在这里分享一下,用j ...

  5. 用html +js+css 实现页面轮播图效果

    html 页面 <html lang="en"> <head> <meta charset="UTF-8"> <met ...

  6. js访3d上下轮播图

    js/css访3d上下轮播图 (附件) <!DOCTYPE html> <html> <head> <meta charset="utf-8&quo ...

  7. 用js和jQuery做轮播图

    Javascript或jQuery做轮播图 css样式 <style> a{ text-decoration:none; } .naver{ width: 100%; position:r ...

  8. JS框架_(Bootstrap.js)实现简单的轮播图

    Bootstrap框架中 轮播(Carousel)插件是一种灵活的响应式的向站点添加滑块的方式 轮播图效果: <!DOCTYPE html> <html> <head&g ...

  9. 原生js写一个无缝轮播图插件(支持vue)

    轮播图插件(Broadcast.js) 前言:写这个插件的原因 前段时间准备用vue加上网易云的nodejs接口,模拟网易云音乐移动端.因为想自己写一遍所有的代码以及加固自己的flex布局,所以没有使 ...

随机推荐

  1. 【奇淫巧技】sqlmap绕过过滤的tamper脚本分类汇总

    sqlmap绕过过滤的tamper脚本分类汇总

  2. 【题解】 P2734 [USACO3.3]游戏 A Game

    \(\color{purple}{Link}\) \(\text{Solution:}\) 考虑区间\([l,r]\)的最优解.显然它可以由\([l+1,r]\)或\([l,r-1]\)转移而来.至此 ...

  3. 全方位剖析 Linux 操作系统,太全了!!!

    Linux 简介 UNIX 是一个交互式系统,用于同时处理多进程和多用户同时在线.为什么要说 UNIX,那是因为 Linux 是由 UNIX 发展而来的,UNIX 是由程序员设计,它的主要服务对象也是 ...

  4. spring框架bean注入

    今天学习了spring框架,刚刚入门简单的了解了spring并学习了bean的注入IOC:IOC(Inversion of Control,控制反转)不是什么技术,而是一种设计思想.它的目的是指导我们 ...

  5. 如何解决Win7,win8无法使用DOS的Debug:

    如何解决Win7,win8无法使用DOS的Debug: 安装dosbox 将含有程序link,masm,edit,debug的文件夹masm放到d盘根目录 打开dosbox,输入mount c d:\ ...

  6. IDEA 简拼输入

    1. sout = System.out.println(); 2. soutp = System.out.println(""); 3. soutv = System.out.p ...

  7. 【数论】HAOI2012 容易题

    题目大意 洛谷链接 有一个数列A已知对于所有的\(A[i]\)都是\(1~n\)的自然数,并且知道对于一些\(A[i]\)不能取哪些值,我们定义一个数列的积为该数列所有元素的乘积,要求你求出所有可能的 ...

  8. Logstash 国内加速下载 转

    Logstash. 国内直接从官网(https://www.elastic.co)下载比较困难,需要一些技术手段.这里提供一个国内的镜像下载地址列表,方便网友下载. 找不到想要的版本?您可以访问 索引 ...

  9. lumen发送邮件配置

    composer.json 增加 "illuminate/mail":"5.6"composer update -vvvconfig 目录新建mail.php ...

  10. HTML <big> 标签

    HTML <big> 标签 什么是<big> 标签? <big> 标签呈现大号字体效果. 使用 <big> 标签可以很容易地放大字体.这简直不能再简单了 ...