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各种复制代码收集
Sep 20 Javascript
nullJavascript中创建对象的五种方法实例
May 07 Javascript
学习Javascript面向对象编程之封装
Feb 23 Javascript
网页前端登录js按Enter回车键实现登陆的两种方法
May 10 Javascript
jquery实现垂直和水平菜单导航栏
Aug 27 Javascript
JavaScript拖动层Div代码
Mar 01 Javascript
JS实现双击内容变为可编辑状态
Mar 03 Javascript
浅谈es6 javascript的map数据结构
Dec 14 Javascript
使用vue完成微信公众号网页小记(推荐)
Apr 28 Javascript
详解Vue-Router源码分析路由实现原理
May 15 Javascript
uploadify插件实现多个图片上传并预览
Sep 30 Javascript
通过GASP让vue实现动态效果实例代码详解
Nov 24 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中调用ASP.NET的WebService的代码
2011/04/22 PHP
php打印一个边长为N的实心和空心菱型的方法
2015/03/02 PHP
PHP动态柱状图实现方法
2015/03/30 PHP
PHP二维数组矩形转置实例
2016/07/20 PHP
PHP中OpenSSL加密问题整理
2017/12/14 PHP
PHP实现求连续子数组最大和问题2种解决方法
2017/12/26 PHP
laravel框架路由分组,中间件,命名空间,子域名,路由前缀实例分析
2020/02/18 PHP
js几个不错的函数 $$()
2006/10/09 Javascript
非常不错的一个javascript 类
2006/11/07 Javascript
IE Firefox 使用自定义标签的区别
2009/10/15 Javascript
js获取html参数及向swf传递参数应用介绍
2013/02/18 Javascript
JS取request值以及自动执行使用示例
2014/02/24 Javascript
JavaScript中的console.log()函数详细介绍
2014/12/29 Javascript
JS+DIV实现鼠标划过切换层效果的方法
2015/05/25 Javascript
深入理解jQuery之事件移除
2016/06/02 Javascript
浅谈EasyUI常用控件的禁用方法
2016/11/09 Javascript
jQuery菜单实例(全选,反选,取消)
2017/08/28 jQuery
Vue实现数字输入框中分割手机号码的示例
2017/10/10 Javascript
vuejs+element UI点击编辑表格某一行时获取内容填入表单的示例
2018/10/31 Javascript
axios实现简单文件上传功能
2019/09/25 Javascript
详解vue中多个有顺序要求的异步操作处理
2019/10/29 Javascript
[14:19]2018年度COSER大赛-完美盛典
2018/12/16 DOTA
python进阶教程之循环相关函数range、enumerate、zip
2014/08/30 Python
Python socket实现简单聊天室
2018/04/01 Python
详解python之heapq模块及排序操作
2019/04/04 Python
纯css3实现图片翻牌特效
2015/03/10 HTML / CSS
css3动画 小球滚动 js控制动画暂停
2019/11/29 HTML / CSS
Python是如何进行类型转换的
2013/06/09 面试题
自行车租赁公司创业计划书
2014/01/28 职场文书
安全生产承诺书
2014/03/26 职场文书
股权转让协议书范本
2014/04/12 职场文书
签约仪式策划方案
2014/06/02 职场文书
领导班子“四风问题”“整改方案
2014/10/02 职场文书
2014年合同管理工作总结
2014/12/02 职场文书
担保公司2015年终工作总结
2015/10/14 职场文书
2016年十一促销广告语
2016/01/28 职场文书