序一(08/07/06)
看到alibaba的一个图片切换效果,感觉不错,想拿来用用。但代码一大堆的,看着昏,还是自己来吧。
由于有了做图片滑动展示效果的经验,做这个就容易得多了。
序二(09/03/19)
自写了Tween缓动之后就很想重新写过这个效果,近来有点时间,终于可以动手了。
除了改成Tween缓动,也改进了程序算法,不过原理还是一样的。
前台效果预览
完整实例下载
程序说明
原理就是通过不断设置滑动对象的left(水平切换)和top(垂直切换)来实现图片切换的动态效果。
首先需要一个容器,程序会自动设置容器overflow为hidden,如果不是相对或绝对定位会同时设置position为relative,
滑动对象会设置为绝对定位:
var p = CurrentStyle(this._container).position;
p == "relative" || p == "absolute" || (this._container.style.position = "relative");
this._container.style.overflow = "hidden";
this._slider.style.position = "absolute";
如果没有设置Change切换参数属性,会自动根据滑动对象获取:
this.Change = this.options.Change ? this.options.Change :
this._slider[bVertical ? "offsetHeight" : "offsetWidth"] / this._count;
执行Run方法就会开始进入切换,其中有一个可选参数用来重新设置要切换的图片索引:
index == undefined && (index = this.Index);
index < 0 && (index = this._count - 1) || index >= this._count && (index = 0);
之后就到设置使用
tween缓动时需要的参数了,
包括_target(目标值)、_t(时间)、_b(初始值)和_c(变化量):
this._target = -Math.abs(this.Change) * (this.Index = index);
this._t = 0;
this._b = parseInt(CurrentStyle(this._slider)[this.options.Vertical ? "top" : "left"]);
this._c = this._target - this._b;
还有Duration(持续时间)是自定义属性。
参数设置好后就执行Move程序开始移动了。
里面很简单,首先判断_c是否有值(等于0表示不需要移动)和_t是否到达Duration,
未满足条件就继续移动,否则直接移动到目标值并进行下一次切换:
if (this._c && this._t < this.Duration) {
this.MoveTo(Math.round(this.Tween(this._t++, this._b, this._c, this.Duration)));
this._timer = setTimeout(Bind(this, this.Move), this.Time);
}else{
this.MoveTo(this._target);
this.Auto && (this._timer = setTimeout(Bind(this, this.Next), this.Pause));
}
使用说明
实例化需要3个参数,分别是容器对象,滑动对象和切换数量,之后可以直接执行Run方法运行:
new SlideTrans("idContainer", "idSlider", 3).Run();
还有以下可选属性:
Vertical: true,//是否垂直方向(方向不能改)
Auto: true,//是否自动
Change: 0,//改变量
Duration: 50,//滑动持续时间
Time: 10,//滑动延时
Pause: 2000,//停顿时间(Auto为true时有效)
onStart: function(){},//开始转换时执行
onFinish: function(){},//完成转换时执行
Tween: Tween.Quart.easeOut//tween算子
其中Vertical初始化后就不能修改,
Tween算子可参照这里的缓动效果选择(实例中选了其中3个)。
还有提供了以下方法:
Next: 切换下一个
Previous: 切换上一个
Stop: 停止自动切换
还有上面说到的Run
其他图片展示效果:
JavaScript 图片变换效果(ie only)
JavaScript 图片滑动展示效果
- 大小: 48 KB
分享到:
相关推荐
JavaScript图片滑动切换效果 仿淘宝/alibaba图片切换
JavaScript,图片,切换,滑动,变换,Tween,缓动,图片切换,slide,展示
~ JavaScript 图片滑动幻灯效果 无Flash~ 效果很好!
javascript 手指滑动切换图片 幻灯片效果
JavaScript图文混排滑动切换效果,看上去像是一个文章排行,当你把鼠标放上的时候就会发现奥妙了,鼠标每移动一行,就会出现对应的图片。这样会增加一些吸引力,指引用户浏览网页。
JavaScript实现图片切换,主要用到setInterval()函数和clearInterval()函数,前者功能是开启动画,后者功能则为清除动画(可理解为使动画停止),为了使动画停止,则需要定义全局变量作为标志,标志返回setInterval...
jQuery图片重叠滑动切换效果代码.zip
nVida网站的图片滑动特效,这里为了快速演示效果,去掉了原有的图片用数字来代替,你完全可以插入你想要的图片,本特效使用JS实现,用CSS配合固定图片,以滑动的方式切换相应的多张图片。
腾讯首页图片滑动效果 JavaScript代码
可左右拖拽切图、轮播等滑动切换效果。只需要替换图片的地址数组,就能实现与数据库或文件交互,下方的缩略图部分自适应比例。兼容各大主流浏览器,兼容各种分辨率,该例实现的难点在于定位与分辨率的调节
主要介绍了js实现支持手机滑动切换的轮播图片效果,实例分析了javascript实现图片切换的相关技巧,非常具有实用价值,需要的朋友可以参考下
html+css+js实现的多款图片照版切换、翻转、滑动展示效果源码
一款非常精美的jQuery+css3图文布局手风琴滑动切换代码,图片结合文字内容介绍横向手风琴展示效果。
看到alibaba的一个图片切换效果,感觉不错,想拿来用用。但代码一大堆的,看着昏,还是自己来吧。由于有了做图片滑动展示效果的经验,做这个就容易得多了。
先说一种最普遍的思路: 把图片们用ul之类的包起来,并设置float。... XScroll.js完成后,我始终觉得他的系统消耗是个问题,因为他实现一个图片切换基本上都是同时操作两张图片。所以我想写一个精简版
SlideView 是一款基于Js高手所写的插件CJL.0.1.min.js编写而成,用来形成div、图片等的滑动展示效果,用它我们可以制作一些滑动导航菜单、图片切换展示等,比较典型的手风琴菜单就是基于本插件完成,现在示例包中有...
主要介绍了JS+CSS实现自动改变切换方向图片幻灯切换效果的方法,实例分析了javascript操作图片切换方向的幻灯片技巧,具有一定参考借鉴价值,需要的朋友可以参考下