42.项目 1-博客前端:封装库--轮播器

学习要点:

1.问题所在
2.设置代码

本节课,我们使用动画功能来完成一组轮播器的功能,轮播器分为透明轮播器和上下滚
动轮播器,希望改变一个值可以切换这两种轮播器。

一.问题所在

QQ截图20190518092428.png

二.设置代码

HTML 代码

<div id="banner">
<imgsrc="images/banner1.jpg" alt="轮播器第一张图"/>
<img src="images/banner2.jpg" alt="轮播器第二张图"/>
<img src="images/banner3.jpg" alt="轮播器第三张图"/>
<ul>
<li class="banner1">●</li>
<li class="banner2">●</li>
<li class="banner3">●</li>
</ul>
<span>半透明黑条</span>
<strong>图片说明</strong>
</div>

CSS 代码

#banner {
width:900px;
height:150px;
margin:10px 0;
float:left;
position:relative;
overflow:hidden;
}
#banner img {
display:block;
position:absolute;
left:0;
}
#banner ul {
position:absolute;
top:128px;
left:420px;
z-index:4;
}
#banner ul li {
float:left;
padding:0 5px;
color:#999;
cursor:pointer;
font-size:16px;
}
#banner span {
display:block;
width:900px;
height:25px;
background:#333;
position:absolute;
top:125px;
left:0;
opacity:0.3;
filter:alpha(opacity=30);
z-index:3;
}
#banner strong {
position:absolute;
top:130px;
left:10px;
color:#fff;
z-index:4;
}

JS 代码

//轮播器初始化
$('#banner img').opacity(0);
$('#banner img').eq(0).opacity(100);
$('#banner strong').html($('#banner img').eq(0).attr('alt'));
$('#banner ul li').eq(0).css('color', '#333');
//轮播器坐标
for (var i = 0; i < $('#banner img').length(); i ++) {
$('#banner img').eq(i).css('top', 0 + (i * 150) + 'px');
}
//轮播计数器
var banner_index = 1;
//轮播器类别
var banner_type = 2; //1 是透明度轮播,2 是上下滚动轮播
//轮播器自动播放
var banner_timer = setInterval(banner_fn, 3000);
//轮播器手动播放
$('#banner ul li').hover(function () {
clearInterval(banner_timer);
if ($(this).css('color') != 'rgb(51, 51, 51)') {
banner(this, banner_index == 0 ? $('#banner ul li').length() - 1 : banner_index - 1);
}
}, function () {
banner_index = $(this).index() + 1;
banner_timer = setInterval(banner_fn, 3000);
});
function banner(obj, prev) {
if (banner_type == 1) {
$('#banner img').css('zIndex', 1);
$('#banner ul li').css('color', '#999');
$(obj).css('color', '#333');
$('#banner strong').html($('#banner img').eq($(obj).index()).attr('alt'));
$('#banner img').eq(prev).animate({
attr : 'o',
target : 0,
t : 30,
step : 10
});
$('#banner img').eq($(obj).index()).animate({
attr : 'o',
target : 100,
t : 30,
step : 10
}).css('top', 0).css('zIndex', 2);
} else if (banner_type == 2) {
$('#banner img').opacity(100);
$('#banner img').css('zIndex', 1);
$('#banner ul li').css('color', '#999');
$(obj).css('color', '#333');
$('#banner strong').html($('#banner img').eq($(obj).index()).attr('alt'));
$('#banner img').eq(prev).animate({
attr : 'y',
target : 150,
t : 30,
step : 10
});
$('#banner img').eq($(obj).index()).animate({
attr : 'y',
target : 0,
t : 30,
step : 10
}).css('top', '-150px').css('zIndex', 2);
}
}
function banner_fn() {
if (banner_index >= $('#banner ul li').length()) banner_index = 0;
banner($('#banner ul li').eq(banner_index).first(), banner_index == 0 ?
$('#banner ul li').length() - 1 : banner_index - 1);
banner_index++;
}
//获取某个节点在某组的位置
Base.prototype.index = function () {
var children = this.elements[0].parentNode.children;
for (var i = 0; i < children.length; i ++) {
if (children[i] == this.elements[0]) return i;
}
};
//获取某个节点的属性
Base.prototype.attr = function (attr) {
return this.elements[0][attr];
};
//设置节点元素的透明度
Base.prototype.opacity = function (num) {
for (var i = 0; i < this.elements.length; i ++) {
this.elements[i].style.opacity = num / 100;
this.elements[i].style.filter = 'alpha(opacity=' + num + ')';
}
return this;
};

感谢收看本次教程!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容

  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,406评论 1 45
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,725评论 1 92
  • 01-recode 1.函数声明 2.函数调用 3.函数的参数 4.返回值 5.全局变量 和 局部变量 6.函数作...
    憨猜猜阅读 98评论 0 1
  • 文|沐歌 说起《色戒》,是好几年前的电影了,围绕它的话题也早已云淡风轻了,当年冒天下之大不韪的汤唯女神也早已熬过那...
    亚姐在东京阅读 20,267评论 46 355
  • 想你的时候 看外面的天空 都刻着你的模样 云彩一动不动 想把你永远呈现 想你的时候 看看外面草地 小草一动不动 摆...
    宓宁阅读 303评论 0 7