【jquery】幻灯片效果
闲着无聊,用Jquery写了一个幻灯片效果。
我这人喜欢造轮子,除了jquery这种有强大开发团队的框架级别JS,其实的一些小程序都是尽量自己写。
一是因为怕出问题了没人问,二是自己写的改起来也方便。
效果可参考:
http://www.helloweba.com/demo/supersized/
只是上面这个DEMO用的是supersized,功能比较强大,就是代码加密过了,读起来很困难。
废话不说,代码放上。
CSS:
img.slider-image {
position:absolute;
display:none;
top:0px;
left:0px;
z-index:-10;
}
img.slider-image.visible {
visibility:visible;
display:inline;
z-index:-1;
}
JS:
2014-12-11 追加:
我把这段代码加到项目里,然后项目马上要结束的时候发现,这货在IE8下面居然无法正常执行。
原因是fadeIn,fadeOut和window.innerWidth 以及 window.innerHeight在IE下无法正常执行。
好吧,一直都是钟爱Chrome,不用IE调试也是我的原罪。
于是我就在代码里加了一个判断,如果是IE的话,就不用fadeIn,fadeOut,
var pic = function (url, parentId,callback) {
this.url = url;
this.id = url.split('/').reverse()[0].split('.')[0];
this.parentId = parentId;
this.img = null;
this.isLoaded = false;
this.load();
this.callback = callback;
}
pic.prototype = {
load: function () {
this.img = new Image();
this.img.src = this.url;
this.img.id = this.id;
this.img.className = "slider-image"; var pic = this;
this.img.onload = function () {
pic.img.onload = null;
pic.img.height = window.innerHeight;
pic.img.width = window.innerWidth;
// 加载完毕,将图片添加到DOM中
$("#" + pic.parentId).append(pic.img);
pic.isLoaded = true;
if (typeof (pic.callback) == "function") {
pic.callback();
}
}
}
} var slider = function (opt) {
this.opt = {
start: false,// 判断幻灯片开始循环
index: 0,
imgsUrl: null,
interval: 5000,// 幻灯片间隔时间
id :"slider"// 幻灯片DIV ID
}
this.imgs = null;
$.extend(this.opt,opt);
this.init();
}
slider.prototype = {
init: function () {
var slider = this;
// 页面添加幻灯片父级DIV
var div = document.createElement('div');
div.id = slider.opt.id;
div.style.display = "block";
document.body.appendChild(div); // 加载图片
var imagesUrls = this.opt.imgsUrl;
this.imgs = new Array();
for (var i = 0; i < imagesUrls.length; i++) {
this.imgs.push(
new pic(imagesUrls[i],
slider.opt.id,
function () {
// 图片加载完毕,立即开始循环幻灯片
if (!slider.opt.start) {
slider.opt.start = true;
slider.start();
}
}
));
}
},
slide: function (slider) {
var imagesSrc = slider.imgs;
var img = imagesSrc[slider.opt.index]; // 循环播放幻灯片
slider.opt.index++;
if (slider.opt.index >= imagesSrc.length) {
slider.opt.index = 0;
}
if (img.isLoaded) {
// 将正在显示的图片淡出,将下一张图片淡入
var diplaying = $('#' + slider.opt.id).find('.visible');
// ie 兼容
if (!jQuery.browser.msie) {
diplaying.fadeOut(2000);
} diplaying.removeClass("visible");
var prepare = $("#" + img.id);
prepare.addClass("visible"); // ie兼容
if (jQuery.browser.msie) {
prepare.css({
"width": document.body.clientWidth,
"height": document.body.clientHeight
});
} else {
prepare.css({
"width": window.innerWidth,
"height":window.innerHeight
});
prepare.fadeIn(1000);
}
} else {
// 如果这张图片没有加载,则立刻显示下张图片
slider.slide(slider);
}
},
start: function () {
var slider = this;
slider.slide(slider)
// 间隔一段时间循环播放幻灯片
setInterval(function () {
slider.slide(slider);
}, this.opt.interval);
}
}
调用的时候,只要执行下面这段代码即可:
new slider({
imgsUrl: ["/Images/Login/slider1.jpg", "/Images/Login/slider2.jpg", "/Images/Login/slider3.jpg"]
});
【jquery】幻灯片效果的更多相关文章
- jquery特效 幻灯片效果
jquery特效 幻灯片效果,效果图如下: <!DOCTYPE html> <html> <head> <meta http-equiv="Cont ...
- 一个很好的幻灯片效果的jquery插件--kinMaxShow
在做一些网站时,或多或少的要给网站做幻灯片效果,以前每次做这个效果,都是现成带网上找,找到的很多很杂,而且用完后就不会再理会更加不会去总结代码. 无意中找到了kinMaxShow这个插件,机会满足了我 ...
- SlidesJS - 老牌的响应式 jQuery 幻灯片插件
SlidesJS 是一款老牌的 jQuery 幻灯片插件,经过多年的发展,已经成为一款功能齐全,设计精巧的幻灯片插件.支持循环.自动播放功能和淡入淡出过渡效果,并且能够自动生成分页,可以帮助开发者制作 ...
- Skippr – 轻量、快速的 jQuery 幻灯片插件
Skippr 是一个超级简单的 jQuery 幻灯片插件.只是包括你的网页中引入 jquery.skippr.css 和 jquery.skippr.js 文件就能使用了.Skippr 能够自适应窗口 ...
- bxSlider 在网页里添加幻灯片效果
幻灯片效果在网页上很常见,本文介绍用 bxSlider 轻松实现的方法. bxSlider是什么 bxSlider 是用 JQuery 和 CSS 实现网页中幻灯片效果的工具.可在 http://bx ...
- 新鲜出炉的30个精美的 jQuery & CSS3 效果【附演示和教程】
新鲜出炉的30个精美的 jQuery & CSS3 效果[附演示和教程] 作为最流行的 JavaScript 开发框架,jQuery 在现在的 Web 开发项目中扮演着重要角色,它简化了 ...
- 18款 非常实用 jquery幻灯片图片切换
1.jquery图片滚动仿QQ商城带左右按钮控制焦点图片切换滚动 jquery图片特效制作仿腾讯QQ商城首页banner焦点图片轮播切换效果,带索引按钮控制和左右按钮控制图片切换. 查看演示>& ...
- jquery幻灯片--渐变
网站上为了设计,需要一些幻灯片效果,现在网站有很多插件可以使用. 想要成为以为牛逼的程序员,绝对不允许只会用别人的插件而已,不然你只能是“代码”的搬运工,而不敢做出自己的创新. 首先使用jquery做 ...
- Prezento – 轻量、简单的 jQuery 幻灯片插件
Prezento 是一个超级简单的 jQuery 幻灯片插件.可以让你网页以新颖的交互方式呈现.另外,Prezento 支持响应式设计,配置项也很灵活,可以根据你需要的效果配置. 您可能感兴趣的相关文 ...
随机推荐
- [POJ1765]November Rain
[POJ1765]November Rain 试题描述 Contemporary buildings can have very complicated roofs. If we take a ver ...
- pro*c调用过程
数据库内有无参数过程名为procedure. pro*c调用过程 EXEC SQL EXECUTE BEGIN procedure; END; END-EXEC; 需要在cfg配置文件 ...
- WebStorm设置左侧菜单栏背景色和样式
WebStrom一直以来都是默认的白色主题,今天想修改了下主题皮肤,结果导致左侧项目资源栏和顶部菜单栏也变成了黑色,结果无法改变回来,网上查了各种帖子,居然也没找到解决方法,自己研究了半天,终于搞定了 ...
- BZOJ 1019: [SHOI2008]汉诺塔
Description 一个汉诺塔,给出了移动的优先顺序,问从A移到按照规则移到另一个柱子上的最少步数. 规则:小的在大的上面,每次不能移动上一次移动的,选择可行的优先级最高的. Sol DP. 倒着 ...
- 项目:BluetoothChat
代码在github: https://github.com/Viyu/BluetoothChat 蓝牙聊天核心是Android Demo里的,我加上了类似微信的界面. 我觉得这个应用要是能推广的话,有 ...
- zend framework2 入门实例代码album模型
下载album模型 一.目录结构说明 - zf_project - config - autoload global.php -- 数据库在这里配置 local.php ...
- Docker的安装配置及使用详解
基本概念 Docker 包括三个基本概念 镜像(Image) 容器(Container) 仓库(Repository) 先理解了这三个概念,就理解了 Docker 的整个生命周期. 1.docker安 ...
- ACM/ICPC 之 数据结构-线段树思想(POJ2182,含O(n^2)插入式解法)
这道题在一定程度上体现了线段树的一种用法,解决的问题是:对于总计n个元素的第i个元素,已知其在[1,i]上部分序列的排名,求第i个元素在所有n个元素中的排名. 当然这道题数据比较水,所以用O(n^2) ...
- MongoDB 查询优化分析
摘要: 在MySQL中,慢查询日志是经常作为我们优化查询的依据,那在MongoDB中是否有类似的功能呢?答案是肯定的,那就是开启Profiling功能.该工具在运行的实例上收集有关MongoDB的写操 ...
- Bootstrap modal垂直居中
Bootstrap modal垂直居中 在网上看到有Bootstrap2的Modal dialog垂直居中问题解决方法,这种方法自己试了一下,并不能完全居中,并且窗口的大小不一样的话,每次显示的m ...