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 相关文章推荐
WEB 浏览器兼容 推荐收藏
May 14 Javascript
jquery ajax修改全局变量示例代码
Nov 08 Javascript
js四舍五入数学函数round使用实例
May 09 Javascript
详谈jQuery中的this和$(this)
Nov 13 Javascript
jQuery中:file选择器用法实例
Jan 04 Javascript
简述Matlab中size()函数的用法
Mar 20 Javascript
javascript运算符语法全面概述
Jul 14 Javascript
javascript 玩转Date对象(实例讲解)
Jul 11 Javascript
最通俗易懂的javascript变量提升详解
Aug 05 Javascript
Vue 页面状态保持页面间数据传输的一种方法(推荐)
Nov 01 Javascript
使用 Vue cli 3.0 构建自定义组件库的方法
Apr 30 Javascript
微信小程序 多行文本显示...+显示更多按钮和收起更多按钮功能
Sep 26 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
深入理解ob_flush和flush的区别(ob_flush()与flush()使用方法)
2013/02/06 PHP
抛弃 PHP 代价太高
2016/04/26 PHP
TP5框架使用QueryList采集框架爬小说操作示例
2020/03/26 PHP
javascript中的undefined 与 null 的区别  补充篇
2010/03/17 Javascript
js修改input的type属性及浏览器兼容问题探讨与解决
2013/01/23 Javascript
三种取消选中单选框radio的方法
2014/09/09 Javascript
jQuery scrollFix滚动定位插件
2015/04/01 Javascript
基于jquery实现瀑布流布局
2020/06/28 Javascript
js实现hashtable的赋值、取值、遍历操作实例详解
2016/12/25 Javascript
Extjs gridpanel 中的checkbox(复选框)根据某行的条件不能选中的解决方法
2017/02/17 Javascript
node.js实现的装饰者模式示例
2017/09/06 Javascript
Vue filter介绍及其使用详解
2017/10/21 Javascript
详解ES6通过WeakMap解决内存泄漏问题
2018/03/09 Javascript
node结合swig渲染摸板的方法
2018/04/11 Javascript
了解Javascript中函数作为对象的魅力
2019/06/19 Javascript
利用d3.js制作连线动画图与编辑器的方法实例
2019/09/05 Javascript
js构造函数constructor和原型prototype原理与用法实例分析
2020/03/02 Javascript
Vue中inheritAttrs的使用实例详解
2020/12/31 Vue.js
[01:10]DOTA2次级职业联赛 - EP战队宣传片
2014/12/01 DOTA
python3中获取文件当前绝对路径的两种方法
2018/04/26 Python
python读取文件名称生成list的方法
2018/04/27 Python
如何利用python查找电脑文件
2018/04/27 Python
python实现微信小程序自动回复
2018/09/10 Python
python批量复制图片到另一个文件夹
2018/09/17 Python
解决pycharm remote deployment 配置的问题
2019/06/27 Python
python安装scipy的步骤解析
2019/09/28 Python
基于Python实现船舶的MMSI的获取(推荐)
2019/10/21 Python
CSS实现聊天气泡效果
2020/04/26 HTML / CSS
分享一个H5原生form表单的checkbox特效代码
2018/02/26 HTML / CSS
iPhoneX安全区域(Safe Area)底部小黑条在微信小程序和H5的屏幕适配
2020/04/08 HTML / CSS
为什么要优先使用同步代码块而不是同步方法?
2013/01/30 面试题
实习教师自我鉴定
2013/12/12 职场文书
公证委托书模板
2014/04/03 职场文书
餐饮投资计划书
2014/04/25 职场文书
小学红领巾广播稿(3篇)
2014/09/13 职场文书
Mysql基础知识点汇总
2021/05/26 MySQL