宽屏图片轮播html,jQuery实现宽屏图片轮播实例教程

本文实例讲述了jQuery实现宽屏图片轮播实例教程。分享给大家供大家参考。具体如下:

运行效果截图如下:

7299b551992b7cfbb040648a2c6cc46c.png

引入jquery库

构建html

整个代码分为三部分:

1、加载部分loadding ;

2、图片部分,这里图片只能是4张,有心的朋友再改良下吧;

3、TAB按钮部分,当然这里也只能是4个按钮,也需要改进。

CSS样式

这里的CSS可以根据项目需求自定义,不必拘泥于下面的代码,只要弄懂其中的原理就OK了。若你看不懂下面的CSS的话就恶补下吧,在此就不一一讲解了。

.ggLoading, .ggLoading2 {

background-image: url(../images/nav.png);

}

.gg {

width: 100%;

height: 500px;

position: relative;

z-index: 1;

overflow: hidden;

margin: 0 auto;

background: #d3d3d3 url(../images/loading.jpg) repeat-x;

}

.ggLoading {

position: absolute;

left: 40%;

top: 200px;

width: 325px;

text-align: center;

height: 56px;

background-position: 0 -274px;

background-repeat: no-repeat;

line-height: 56px;

color: #9c9c9c;

}

.ggLoading2 {

width: 330px;

height: 56px;

background-position: 213px -330px;

background-repeat: no-repeat;

}

.ggLoading em {

font-weight: bold;

}

.ggs {

width: 200%;

height: 500px;

left: -50%;

top: 0;

position: absolute;

}

.ggBox {

width: 1920px;

height: 500px;

margin: 0 auto;

}

.ggBox a {

display: block;

width: 1920px;

height: 500px;

position: absolute;

z-index: 1;

opacity: 0.1;

}

.ggBox img {

display: block;

width: 1920px;

height: 500px;

}

.ggb {

position: absolute;

width: 100%;

left: 0;

bottom: 0;

height: 40px;

z-index: 4;

background-color: #32342e;

background-repeat: repeat-x;

background-position: 50% -40px;

}

.ggBtns {

width: 960px;

height: 40px;

margin: 0 auto;

border-left: 1px solid #090908;

border-right: 1px solid #6a6a60;

}

.ggBtns a {

float: left;

display: block;

width: 240px;

height: 40px;

text-align: center;

padding-top: 10px;

color: #848380;

font-size: 14px;

line-height: 40px;

background-position: 0 10px;

position: relative;

top: -10px;

outline: none;

background-repeat: no-repeat;

cursor: pointer;

}

.ggBtns a em {

display: block;

width: 210px;

height: 40px;

margin: 0 auto;

overflow: hidden;

}

.ggBtns a:hover {

color: #e7e7e7;

}

.ggBtns a:focus {

outline: none;

}

.ggBtns a.ggOn {

color: #e7e7e7;

background-position: 0 0;

}

.ggb, .ggBtns a {

background-image: url(../images/main.jpg);

}

a.ggOn {

background-image: url(../images/gg.png);

}

JS代码

终于来到重点部分了,这部分的代码不多,一起来看下吧。

$(function () {//文档加载后执行

//定义$con,$box,$btns,$i变量,autoChange自动播放函数,loop定时器。

var $con = $('#gg'), $box = $con.find('#ggBox'), $btns = $con.find('#ggBtns'), i = 0, autoChange = function () {

i += 1;//计数器+1

if (i === 4) { i = 0; }//如果计数器i等4就把i重置为0.

$btns.find('a:eq(' + i + ')').addClass('ggOn').siblings().removeClass('ggOn');

//找到TAB按钮中的第i个a标签,为其加上ggOn的样式,同时移除所有同级的a标签ggOn样式

var curr = $box.find('a:eq(' + i + ')'), prev = curr.siblings();

//定义curr变量,并赋值为$box中当前显示图片的a标签,定义prev变量,赋值为$box中除了当前显示图片的A标签外的所有A标签。

prev.css('z-index', 2);//$box中除了当前显示图片的A标签外的所有A标签的index值变为2,即向下移一层

curr.css('z-index', 3).animate({ //$box中当前显示图片的a标签index值变为3,即向上移一层,然后使用jquery动画以150毫秒把透明度变为1,之后执行匿名函数function。

'opacity': 1

}, 150, function () { //$box中除了当前显示图片的A标签外的所有A标签的index值变为1,并把透明度变为0.1

prev.css({

'z-index': 1, 'opacity': 0.1

});

});

}, loop = setInterval(autoChange, 5000);//定义定时器,每5秒执行一次autoChange函数,达到自动播放效果。

$con.hover(function () { //定义鼠标悬浮与离开事件

clearInterval(loop); //鼠标悬浮时移除Loog定时器,即停止播放

}, function () {

loop = setInterval(autoChange, 5000); //鼠标离开时载放Loog定时器,继续播放

});

$btns.find('a').click(function () {//定义tab按钮事件

i = $(this).index() - 1; //tab按钮中当前A标签的index值-1,并赋值给i计数器

autoChange(); //调用切换方法切换图片

});

});

不知亲们看完以上的注释,知道原理了没有呢?其实整个代码分为四个部分:

1、图片切换以i作为计数器,显示当前为i的图片,其它图片全部隐藏,给当前为i的按钮加上ggOn样式,其它按钮去除ggOn样式,而每次调用切换函数时i自增1。

2、自动播放

定义一个定时器loop,每5秒调用一次切换函数。

3、鼠标hover事件

原来就是鼠标悬浮时清除loop定时器,鼠标离开时载入loop定时器。

4、按钮事件

绑定tab按钮单击事件,单击后给i赋上当前tab按钮的index值-1,调用切换函数。

以上就是jquery实现图片轮播的全部关键性代码,希望大家仔细研究,教程中仍存在许多不足,希望大家予以改进。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值