注册    登录
最新消息: 本以为花钱买了那个amh的板面可以让网站更稳定,结果搞得整 个网站运行出错,真是赔了夫人又折兵,对不起大家了。最新版jquery-2.1.1下载  ,在线的 jquery API使用手册, 稳定版jquery.mobile-1.3.2下载

jQuery制作宽屏焦点图教程

jquery实例 fishcity 1583浏览

jQuery制作焦点图实例

今天分享一款全新的jQuery焦点图,这款jQuery焦点图是宽屏的,外观看上去非常大气,jQ酷分享过很多宽屏的jQuery焦点图插件,但是今天我们拿这个焦点图来当实例教程,详细的解说下,因为代码不多。

jquery实例教程:Query制作宽屏游戏焦点图


引入jquery

<script src="js/jquery-1.9.1.min.js" type="text/javascript"></script>

构建html

整个代码分为三部分,1、加载部分loadding 2、图片部分,这里图片只能是4张,本实例是写死了,有心的朋友再改良下吧。 3、TAB按钮部分,当然这里也只能是4个按钮。

<div class="gg" id="gg">
            <div class="ggLoading">
                <div class="ggLoading2"><em>精彩活动载入中</em></div>
            </div>
            <div class="ggs">
                <div class="ggBox" id="ggBox">
                    <a href="#" title="5月22日测试开启领报名资格" style="z-index: 3; opacity: 4;">
                        <img src="images/1.jpg" alt="" /></a>
                    <a href="#" title="首测世界的雕琢篇章开启">
                        <img src="images/2.jpg" alt="" /></a>
                    <a href="#" title="上古世纪游戏资料手册">
                        <img src="images/3.jpg" alt="" /></a>
                    <a href="#" title="游戏四大特色揭晓">
                        <img src="images/4.jpg" alt="" /></a>
                </div>
            </div>
            <div class="ggb">
                <div class="ggBtns" id="ggBtns">
                    <a title="5月22日测试开启领报名资格" href='javascript:void(0)' class="ggOn"><em>5月22日测试开启领报名资格</em></a>
                    <a title="首测世界的雕琢篇章开启" href='javascript:void(0)'><em>首测世界的雕琢篇章开启</em></a>
                    <a title="上古世纪游戏资料手册" href='javascript:void(0)'><em>上古世纪游戏资料手册</em></a>
                    <a title="游戏四大特色揭晓" href='javascript:void(0)'><em>游戏四大特色揭晓</em></a>
                </div>
            </div>
        </div>

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,调用切换函数。

好了,教程到此结束。

转载请注明:jQ酷 » jQuery制作宽屏焦点图教程

下载地址:本站下载 | 百度云
下载说明:
☉如果您发现本文件已经失效不能下载,请联系站长修正!
☉如果您下载的文件出现解压不了或文件受损等情况,请选择其他下载点重新下载。
☉下载本站资源,如果服务器暂不能下载请过一段时间重试!
☉有小部分资源需要解压密码,请输入:jqcool.net。
☉本站提供的所有资源仅供学习研究与参考,请勿用于商业用途。