jQuery轮 播的封装

  今天来聊聊jQuery轮播的封装!

  我自己封装了一个图片宽1200px,高400px的无缝滚动轮播图;话不多说看看代码吧!

Js:

/**
 * Created by Administrator on 2017/7/1 0001.
 */
$(function(){
    var timer1=null;
    var timer2=null;
    var q=1;
    var x=-1200;    //刚开始让第一张图片展现出来
//            向左移动
    leftstar()
    function leftstar(){
        //设定计时器
        timer1=setInterval(function(){
            //每走完一张,对应小白点对应显示
            if(x%1200==0){
                stop(1);//关闭向右走的计时器
                xiaobia(Math.abs(x/1200)-1)
            }
            //当一轮图片走完,又返回原来的为位置接着走,依次循环
            if(x==-6000){
                x=-1200;
            }
            $("#imgs").css("left",x+"px");
            x-=5
        },30)
    }
//            向右移动
    function rightstar(){
        timer1=setInterval(function(){
            if(x%1200==0){
                stop(2);//关闭向左走的计时器
                xiaobia(Math.abs(x/1200)-1)
            }
            if(x==0){
                x=-4800;
            }
            $("#imgs").css("left",x+"px");
            x+=5

        },30)
    }
//            停止计时器
    function stop(q){
        clearInterval(timer1);
        clearTimeout(timer2);
        if(q==1){
            timer2=setTimeout(leftstar,500)
        }
        if(q==2){
            timer2=setTimeout(rightstar,500)
        }
    }

//            移入移出
    $("#banner").hover(function(){
        stop()
    },function(){
        stop(q)
    });
    //向左走的按钮
    $("#left_Btn").click(function(){
        stop(1)
        q=1;
    });
    //向右走的按钮
    $("#right_Btn").click(function(){
        stop(2)
        q=2;
    })

//            小白点
    function xiaobia(num){
        if(num==4){
            num=0
        }
        if(num==-1){
            num=3
        }
        $("#biao li").eq(num).css("background","red")
        $("#biao li").eq(num).siblings().css("background","white")
    }
    $("#biao li").hover(function(){
        xiaobia($(this).index())
        $("#imgs").css("left",-($(this).index()*1200)-1200)
        x=-($(this).index()*1200)-1200
    })
})

css:

/*4+2   width:1200px;*/
*{
    margin: 0;
    padding: 0;
}

/*最外层的div*/
#banner{
    width: 1200px;
    height: 400px;
    position: relative;
    top: 100px;
    left: 10%;
    overflow: hidden;
}
/*包裹图片的ul*/
#imgs{
    width: 7200px;
    height: 400px;
    position: absolute;
    left: -1200px;
}
#imgs li{
    float: left;
    list-style: none;
}
#imgs li img{
    width: 1200px;
    height: 400px;
}
/*小圆点的父级*/
#biao{
    width: 200px;
    height: 50px;
    position: absolute;
    left: 35%;
    bottom: 0;
}
/*小圆点*/
#biao li{
    float: left;
    list-style: none;
    margin-left: 20px;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    color: #007ed9;
    line-height: 30px;
    background: white;
    text-align: center;
}
/*左右按钮的父级*/
ol{
    width: 1200px;
    height: 50px;
    text-align: center;
    line-height: 50px;
    position: absolute;
    left: 0;
    top:35%;
}
ol li{
    font-size: 30px;
    list-style: none;
    width: 50px;
    height: 50px;
    color: white;
    position: absolute;
    background: rgba(0,0,0,.5);
}
/*左按钮*/
#left_Btn{
    left: 0;
}
/*右按钮 */
#right_Btn{
    right: 0;
}

html:

/*4+2   width:1200px;*/
*{
    margin: 0;
    padding: 0;
}

/*最外层的div*/
#banner{
    width: 1200px;
    height: 400px;
    position: relative;
    top: 100px;
    left: 10%;
    overflow: hidden;
}
/*包裹图片的ul*/
#imgs{
    width: 7200px;
    height: 400px;
    position: absolute;
    left: -1200px;
}
#imgs li{
    float: left;
    list-style: none;
}
#imgs li img{
    width: 1200px;
    height: 400px;
}
/*小圆点的父级*/
#biao{
    width: 200px;
    height: 50px;
    position: absolute;
    left: 35%;
    bottom: 0;
}
/*小圆点*/
#biao li{
    float: left;
    list-style: none;
    margin-left: 20px;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    color: #007ed9;
    line-height: 30px;
    background: white;
    text-align: center;
}
/*左右按钮的父级*/
ol{
    width: 1200px;
    height: 50px;
    text-align: center;
    line-height: 50px;
    position: absolute;
    left: 0;
    top:35%;
}
ol li{
    font-size: 30px;
    list-style: none;
    width: 50px;
    height: 50px;
    color: white;
    position: absolute;
    background: rgba(0,0,0,.5);
}
/*左按钮*/
#left_Btn{
    left: 0;
}
/*右按钮 */
#right_Btn{
    right: 0;
}

这个封装只能适用于图片宽为1200px,高为400px的一个轮播图。

  

时间: 2024-12-28 09:49:58

jQuery轮 播的封装的相关文章

JQ 图片轮播并封装

利用面向对象自己动手写了一个封装好的jquery轮播对象,可满足一般需求,需要使用时只需调用此对象的轮播方法即可. demo:https://github.com/zsqosos/shopweb 具体代码如下: HTML结构: 1 <div class="banner" id="J_bg_ban"> 2 <ul> 3 <li><a href="#"><img src="banner_

JQuery仿最新淘宝网首页带箭头幻灯片,JQuery轮播图

JQuery代码 <script type="text/javascript"> $(function() { var $banner = $('.banner'); var $banner_ul = $('.banner-img'); var $btn = $('.banner-btn'); var $btn_a = $btn.find('a') var v_width = $banner.width(); var page = 1; var timer = null;

UISCrollView —— 图片轮播器封装实现(三)——(第三讲)

1.分析 利用xib布局,然后自定义一个UIView,解析xib,然后利用控制器传入数据,将其加载到控制器的view上展示即可 2. 程序结构 3. 代码具体实现 1>  xib文件 2>  创建类 XMGPageView,然后将其与xib文件关联,选中xib文件,然后设置下文中 " custom class " 为定义的类,让其来管理xib 1>    (如图,设置xib与类关联) 2>  XMGPageView.h 文件中,声明分页图片数组属性,及其一个快速

jquery轮播图

咱们今天还是轮播图,今天说jquery的轮播图! 首先,要有个插件: 请无视Zepto插件,他没起到任何作用! 就是这两个啦! 然后就是代码! <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <!--引入插件--> <script src="../上月插件/jquery-3.1.1.min.js&q

今天修改网站的一个jquery轮播收获了新大陆

想想有一段时间没写博客了,主要是最近太懒,加上没有让自己眼前一亮的技术点,故最近都在尝试使用git管理版本,对于版本管理这方面真的是觉得,如果你用了git,你会爱上这个东西,神器! 今天主要是积累一个原生jquery写的类似于手动的轮播,很喜欢这个写法,特此积累一下. 1 <!doctype html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <

Jquery 轮播图简易框架

=====================基本结构===================== <div class="carousel" style="width: 800px;height: 378px;"> <ul class="carousel-imgs"> <li> <a href="#"><img src="picture.jpg" alt=&

支持触屏的jQuery轮播图插件

移动轮播图我看到两类, 一款是无线天猫的m.tmall.com和携程,实现了无缝轮播. 一款是蘑菇街的,没有实现无缝轮播. 我自己重写一个,类似天猫.不过功能上简单点,只实现支持触屏和无缝轮播. 1.页面代码 1 <!DOCTYPE html> 2 <html xmlns="http://www.w3.org/1999/xhtml" lang="UTF-8"> 3 <head> 4 <meta charset="U

jquery轮播(自动+下标)

主要是  要元旦了 事情多 所以就先发了   有不足的地方 请多指出. 1.HTML <div class="slideBox" id="slideBox"> <div class="btn"> <span class="left"><</span> <span class="right">></span> </div

超炫酷的jQuery轮播焦点图 底部带切换缩略图

详细内容请点击 前面我们刚刚分享过一款jQuery/HTML5响应式焦点图动画应用,效果非常炫酷.这次我们再来分享一款基于jQuery的图片轮播焦点图,这款jQuery焦点图的特点是整个图片播放器是宽屏的效果,并且在焦点图底部有一排可以滑动的缩略图,点击缩略图可以快速跳转到相应的图片.  在线演示源码下载 学习来源:http://www.html5tricks.com/jquery-cool-image-slider-thumb.html 更多html5内容请点击