本文实例讲述了JS实现的相册图片左右滚动效果。分享给大家供大家参考,具体如下:

执行左移右移函数:

var $get = function(id) {

return "string" == typeof id ? document.getElementById(id) : id;

};

var Extend = function(destination, source) {

for (var property in source) {

destination[property] = source[property];

}

return destination;

}

var CurrentStyle = function(element) {

return element.currentStyle || document.defaultView.getComputedStyle(element, null);

}

var Bind = function(object, fun) {

var args = Array.prototype.slice.call(arguments).slice(2);

return function() {

return fun.apply(object, args.concat(Array.prototype.slice.call(arguments)));

}

}

var Tween = {

Quart: {

easeOut: function(t, b, c, d) {

return -c * ((t = t / d - 1) * t * t * t - 1) + b;

}

},

Back: {

easeOut: function(t, b, c, d, s) {

if (s == undefined) s = 1.70158;

return c * ((t = t / d - 1) * t * ((s + 1) * t + s) + 1) + b;

}

},

Bounce: {

easeOut: function(t, b, c, d) {

if ((t /= d) < (1 / 2.75)) {

return c * (7.5625 * t * t) + b;

} else if (t < (2 / 2.75)) {

return c * (7.5625 * (t -= (1.5 / 2.75)) * t + .75) + b;

} else if (t < (2.5 / 2.75)) {

return c * (7.5625 * (t -= (2.25 / 2.75)) * t + .9375) + b;

} else {

return c * (7.5625 * (t -= (2.625 / 2.75)) * t + .984375) + b;

}

}

}

}

//容器对象,滑动对象,切换数量

var SlideTrans = function(container, slider, count, options) {

this._slider = $get(slider);

this._container = $get(container); //容器对象

this._timer = null; //定时器

this._count = Math.abs(count); //切换数量

this._target = 0; //目标值

this._t = this._b = this._c = 0; //tween参数

this.Index = 0; //当前索引

this.SetOptions(options);

this.Auto = !!this.options.Auto;

this.Duration = Math.abs(this.options.Duration);

this.Time = Math.abs(this.options.Time);

this.Pause = Math.abs(this.options.Pause);

this.Tween = this.options.Tween;

this.onStart = this.options.onStart;

this.onFinish = this.options.onFinish;

var bVertical = !!this.options.Vertical;

this._css = bVertical ? "top" : "left"; //方向

//样式设置

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";

this.Change = this.options.Change ? this.options.Change :

this._slider[bVertical ? "offsetHeight" : "offsetWidth"] / this._count;

};

SlideTrans.prototype = {

//设置默认属性

SetOptions: function(options) {

this.options = {//默认值

Vertical: true, //是否垂直方向(方向不能改)

Auto: false, //是否自动

Change: 0, //改变量

Duration: 50, //滑动持续时间

Time: 10, //滑动延时

Pause: 2000, //停顿时间(Auto为true时有效)

onStart: function() { }, //开始转换时执行

onFinish: function() { }, //完成转换时执行

Tween: Tween.Quart.easeOut//tween算子

};

Extend(this.options, options || {});

},

//开始切换

Run: function(index) {

//修正index

index == undefined && (index = this.Index);

index < 0 && (index = this._count - 1) || index >= this._count && (index = 0);

//设置参数

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;

this.onStart();

this.Move();

},

//移动

Move: function() {

clearTimeout(this._timer);

//未到达目标继续移动否则进行下一次滑动

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));

}

},

//移动到

MoveTo: function(i) {

this._slider.style[this._css] = i + "px";

},

//下一个

Next: function() {

this.Run(++this.Index);

},

//上一个

Previous: function() {

this.Run(--this.Index);

},

//停止

Stop: function() {

clearTimeout(this._timer); this.MoveTo(this._target);

}

};

在前天html加入div容器:

Pre

Next

下面是改变左右按钮可用状态

var imgNum = $get("idContainer").getElementsByTagName("img").length;

var pre = $get("Pre");

var next = $get("Next");

var i = 0;

if (imgNum > 0) {

var st = new SlideTrans("idContainer", "idSlider", 3, { Vertical: false });

if (i < 2) {

$get("Next").onclick = function() {

if (i < 2) {

st.Next();

i++;

if (i == 1) {

$get("ImgPre").src = "ImageV3/Default/pre-green.png";

pre.style.color = "#2f6417";

}

if (i == 2) {

$get("ImgNext").src = "ImageV3/Default/next-gray.png";

next.style.color = "Gray";

}

ChangePicIndex(i);

}

}

}

$get("Pre").onclick = function() {

if (i > 0) {

st.Previous();

$get("ImgNext").src = "ImageV3/Default/next-green.png";

next.style.color = "#2f6417";

i--;

if (i == 0) {

$get("ImgPre").src = "ImageV3/Default/pre-gray.png";

pre.style.color = "Gray";

}

ChangePicIndex(i);

}

}

st.Run();

}

function ChangePicIndex(index) {

switch (index) {

case 1:

$get("Img1").src = "ImageV3/Default/graydot.png";

$get("Img2").src = "ImageV3/Default/greendot.png";

$get("Img3").src = "ImageV3/Default/graydot.png";

break

case 2:

$get("Img1").src = "ImageV3/Default/graydot.png";

$get("Img2").src = "ImageV3/Default/graydot.png";

$get("Img3").src = "ImageV3/Default/greendot.png";

break

default:

$get("Img1").src = "ImageV3/Default/greendot.png";

$get("Img2").src = "ImageV3/Default/graydot.png";

$get("Img3").src = "ImageV3/Default/graydot.png";

}

}

希望本文所述对大家JavaScript程序设计有所帮助。

相册左右滑动html,JS实现的相册图片左右滚动完整实例相关推荐

  1. 3.8 JS 制作无间断图片循环滚动效果

    制作无间断图片循环滚动效果 要求图片高度,高度自行设定,要求显示n张图片(n=你的学号末位+6),例如:你的学号末位是3,那么你需要显示3+6共9张图片,9张图片循环滚动 index.html < ...

  2. 上传图片显示扫描效果html5,JS+HTML5实现上传图片预览效果完整实例【测试可用】...

    本文实例讲述了JS+HTML5实现上传图片预览效果.分享给大家供大家参考,具体如下: 在项目中遇到用input标签file类型的文件上传,想实在上传之前进行图片的预览功能:之前的做的一个解决方案是文件 ...

  3. JS实现的五级联动菜单效果完整实例

    https://www.jb51.net/article/106525.htm 本文实例讲述了JS实现的五级联动菜单效果.分享给大家供大家参考,具体如下: js实现多级联动的方法很多,这里给出一种5级 ...

  4. php跳一跳小游戏,原生JS实现的跳一跳小游戏完整实例

    本文实例讲述了原生JS实现的跳一跳小游戏.分享给大家供大家参考,具体如下: 以下说的是闲暇编写的一个小游戏--跳一跳,类似于微信的跳一跳,大体实现功能有: 1.先随机生成地图: 2.按住按钮释放后完成 ...

  5. js des加密 java_Java实现与JS相同的Des加解密算法完整实例

    本文实例讲述了Java实现与JS相同的Des加解密算法.分享给大家供大家参考,具体如下: 这里演示java与js实现相同的des加解密算法,不多说,不废话,直接上代码 一.java实现 package ...

  6. html实现跳跳棋游戏,原生JS实现的跳一跳小游戏完整实例

    本文实例讲述了原生JS实现的跳一跳小游戏.分享给大家供大家参考,具体如下: 以下说的是闲暇编写的一个小游戏--跳一跳,类似于微信的跳一跳,大体实现功能有: 1.先随机生成地图: 2.按住按钮释放后完成 ...

  7. 解惑:如何使用html+css+js实现旋转相册,立方体相册等动画效果

    解惑:如何使用html+css+js实现旋转相册,立方体相册等动画效果 一.前言 最初还是在抖音上看到可以使用简单地代码实现炫酷的网页效果的,但是想要找到可以运行的代码还是比较困难的,最近突然想起就在 ...

  8. 使用html+css+js实现3D相册

    使用html+css+js实现3D相册,快来上传的照片吧 效果图: 代码如下,复制即可用: <!DOCTYPE html> <html lang="en"> ...

  9. 程序员520❤七夕情人节表白代码Html+Js+Css花瓣相册网页模板❤程序员表白必备

    ❉ 520程序员求婚Html+Js+Css花瓣相册❤ (爱心3D动画,自定义文字)/ 程序员表白必备 一年一度的/520情人节/七夕情人节/生日礼物/告白师妹/程序员表白, 非常经典的程序员式的表达爱 ...

最新文章

  1. Python (2) 除法
  2. CSS中可以or不可以继承的属性
  3. Laravel添加验证场景提高针对性质的验证
  4. mysql adminer 导入csv_mysql导入csv的4种报错的解决方法
  5. c语言case label,an enum switch case label must be the unqualified name of an enumeration constant
  6. Linux 字符集 en_us,Linux语言环境:en_US.UTF-8 vs en_US
  7. Lua-pb 升级到Lua5.3
  8. 面试题51. 数组中的逆序对
  9. Ubuntu下安装Oracle Instant Client
  10. 虹软人脸识别java调用依赖Cant‘t find dependent library错误,需安装vc2013运行环境
  11. 编写一个油猴脚本,去除百度首页的广告卡片(亲测有效)
  12. 广东工业大学2020级年ACM第一次月赛
  13. 【常系数线性递推】51nod1538 一道难题
  14. ospf(开放式最短路径优先协议)
  15. 有趣好玩的html页面,有趣的HTML5网站集合 - 小俊学习网
  16. 西门子S7-1200PLC和KTP700触摸屏通过USS协议控制MM420变频器
  17. AtCoder Grand Contest 012 B Splatter Painting(记忆化搜索)
  18. 显示手机键盘的回车换行
  19. centos7升级内核重启问题:you need to load the kernel first
  20. 化学类调剂计算机,汕头大学理学院计算机化学方向招收收985、211院校本科毕业考研调剂生 - 考研 - 小木虫 - 学术 科研 互动社区...

热门文章

  1. Webpack5之CSS3自动补齐前缀
  2. DropDownListFor传参数
  3. 为啥我的APP功能引导设计这么low?如何做好功能引导设计?
  4. 智立方董事长杨石头经典语录(仅供…
  5. 【转】HashMap 扩容 无限循环问题
  6. matlab绘制oc曲线,三角网方法绘制等值线图及其在重力资料成图中的应用
  7. 获取radio 选中的值
  8. code-server实现平板编程
  9. 献给即将入读, 正在就读或打算报考研究生的年轻朋友们
  10. 我们必须真正理顺区块链与元宇宙之间的关系