javascript淡入淡出效果的实现思路


Posted in Javascript onMarch 31, 2012

如题,只有思路,没有代码。

这个思路是最近写XScroll.js类的时候想明白的。平常我们说的淡入淡出效果,一般分成两部分,一半是淡入,另一半就是淡出了。不过经过分析,我觉得其实只需要一半就行了。

比如写一个图片切换类,切换效果是淡入淡出,通常我们会这样写:当切换发生的时候,当前显示的图片淡出(渐渐隐藏),将要显示的图片淡入(渐渐出现),通常两张图片的动画速度是一致的,以便实现当前图片完全隐藏之时就是下一张图片完全显示之日。

我们来列一个简单的步骤:

当前图片渐隐,透明度由100%变成90%;同时下一张图片渐显,透明度由0变成10.
当前图透明度80%,下张图透明度20%
当前图70%,下张图30%。
。。。。
当前图10%,下张图90%
完成切换
其实,这样做完全是一种浪费!

我们想一想,如果下张图zIndex位于当前图之上,当它渐显的时候,因为越来越不透明,所以视觉上,他下层的当前图片看起来就越来越透明!

比如,下张图透明度为20%的时候,因为他覆盖在当前图上,所以当前图片看起来透明度就是100%-20%=80%!

所以,在制作淡入淡出切换效果的时候,其实只需要淡入效果即可,淡入的同时,淡出就发生着;淡入结束时,就是淡出终结。这样一来,永远不用担心淡入与淡出不同步的问题。

关键是,这样一来只用同时循环设置一张图片的透明度(即下张图),不用管被挡住的这张(即当前图),节约了一半的运算。这也算是优化了javascript的执行效率吧?

所以,我实现淡入淡出切换效果的思路就是:

将下一张图片的zIndex设置于当前图片之上
下一张图片进行淡入(渐显)循环;当前图片不操作。
淡入进行时,淡出同步发生;淡入完成,淡出同时完成。
注:此思路只适合于当前图与下一张图重叠的情况(大部分时候都是这样)。

Javascript 相关文章推荐
Javascript小技巧之生成html元素
May 15 Javascript
简单讲解AngularJS的Routing路由的定义与使用
Mar 05 Javascript
AngularJS中的包含详细介绍及实现示例
Jul 28 Javascript
vue2.0多条件搜索组件使用详解
Mar 26 Javascript
JS中正则表达式要注意lastIndex属性
Aug 08 Javascript
js HTML5 canvas绘制图片的方法
Sep 08 Javascript
vue.js项目中实用的小技巧汇总
Nov 29 Javascript
详解React项目中碰到的IE问题
Mar 14 Javascript
微信小程序网络请求实现过程解析
Nov 06 Javascript
JavaScript正则表达式验证登录实例
Mar 18 Javascript
JQuery表单元素取值赋值方法总结
May 12 jQuery
解决vue prop传值default属性如何使用,为何不生效的问题
Sep 21 Javascript
提高javascript效率 一次判断,而不要次次判断
Mar 30 #Javascript
一个关于javascript匿名函数的问题分析
Mar 30 #Javascript
JavaScript 基础篇(一)
Mar 30 #Javascript
js确定对象类型方法
Mar 30 #Javascript
js 浏览器事件介绍
Mar 30 #Javascript
js中eval详解
Mar 30 #Javascript
关于jquery性能最佳实践的讨论,与求教
Mar 30 #Javascript
You might like
PHP Switch 语句之学习笔记
2013/09/21 PHP
php中preg_replace正则替换用法分析【一次替换多个值】
2017/01/17 PHP
Javascript 面向对象编程(一) 封装
2011/08/28 Javascript
通过js动态操作table(新增,删除相关列信息)
2012/05/23 Javascript
JQuery入门——用映射方式绑定不同事件应用示例
2013/02/05 Javascript
jQuery setTimeout传递字符串参数报错的解决方法
2014/06/09 Javascript
使用jQuery不判断浏览器高度解决iframe自适应高度问题
2014/12/16 Javascript
jquery中filter方法用法实例分析
2015/02/06 Javascript
终于实现了!精彩的jquery弹幕效果
2016/07/18 Javascript
Node.js开启Https的实践详解
2016/10/25 Javascript
jquery中封装函数传递当前元素的方法示例
2017/05/05 jQuery
通俗易懂地解释JS中的闭包
2017/10/23 Javascript
vue中使用protobuf的过程记录
2018/10/26 Javascript
JavaScript或jQuery 获取option value值方法解析
2020/05/12 jQuery
解决nuxt页面中mounted、created、watch执行两遍的问题
2020/11/05 Javascript
[05:13]2018DOTA2亚洲邀请赛主赛事第二日战况回顾 LGD、VG双雄携手晋级
2018/04/05 DOTA
PYTHON 中使用 GLOBAL引发的一系列问题
2016/10/12 Python
利用python获取当前日期前后N天或N月日期的方法示例
2017/07/30 Python
pycharm远程调试openstack代码
2017/11/21 Python
matplotlib 纵坐标轴显示数据值的实例
2018/05/25 Python
Python多进程原理与用法分析
2018/08/21 Python
Django中数据库的数据关系:一对一,一对多,多对多
2018/10/21 Python
python实现Flappy Bird源码
2018/12/24 Python
python区块及区块链的开发详解
2019/07/03 Python
pytorch模型预测结果与ndarray互转方式
2020/01/15 Python
python实现密码验证合格程序的思路详解
2020/06/01 Python
CSS3中颜色线性渐变实战
2015/07/18 HTML / CSS
基于canvas使用贝塞尔曲线平滑拟合折线段的方法
2018/01/10 HTML / CSS
护理学毕业生求职信
2013/11/14 职场文书
毕业生工作求职信
2014/06/30 职场文书
党的群众路线教育实践活动实施方案
2014/10/31 职场文书
2015年南京大屠杀纪念日活动总结
2015/03/24 职场文书
2015年学生管理工作总结
2015/05/26 职场文书
浅谈移动端中的视口(viewport)的具体使用
2021/04/13 HTML / CSS
压缩Redis里的字符串大对象操作
2021/06/23 Redis
实战Python爬虫爬取酷我音乐
2022/04/11 Python