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 继承机制的实现
Aug 12 Javascript
JavaScript 面向对象编程(1) 基础
May 18 Javascript
实现网页页面跳转的几种方法(meta标签、js实现、php实现)
May 20 Javascript
jquery+ajax实现跨域请求的方法
Jan 20 Javascript
在WordPress中加入Google搜索功能的简单步骤讲解
Jan 04 Javascript
jQuery基于muipicker实现仿ios时间选择
Feb 22 Javascript
JavaScript实现iframe自动高度调整和不同主域名跨域
Feb 27 Javascript
a标签跳转到指定div,jquery添加和移除class属性的实现方法
Oct 10 Javascript
AngularJS入门教程之表单校验用法示例
Nov 02 Javascript
JavaScript中日常收集常见的10种错误(推荐)
Jan 08 Javascript
动态加载css方法实现和深入解析
Jan 18 Javascript
react中的ajax封装实例详解
Oct 17 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
虹吸壶是谁发明的?煮出来的咖啡好喝吗
2021/03/04 冲泡冲煮
php学习笔记 [预定义数组(超全局数组)]
2011/06/09 PHP
Extjs学习笔记之一 初识Extjs之MessageBox
2010/01/07 Javascript
js动态切换图片的方法
2015/01/20 Javascript
JS实现网站菜单拖拽移位效果的方法
2015/09/24 Javascript
JavaScript 七大技巧(二)
2015/12/13 Javascript
深入理解JQuery中的事件与动画
2016/05/18 Javascript
解析jQueryEasyUI的使用
2016/11/22 Javascript
利用select实现年月日三级联动的日期选择效果【推荐】
2016/12/13 Javascript
AngularJS实现路由实例
2017/02/12 Javascript
JS实现评价的星星功能
2017/08/20 Javascript
快速解决Vue项目在IE浏览器中显示空白的问题
2018/09/04 Javascript
JS如何获取地址栏的参数实例讲解
2018/10/06 Javascript
js使用Promise实现简单的Ajax缓存
2018/11/14 Javascript
使用jquery模拟a标签的click事件无法实现跳转的解决
2018/12/04 jQuery
vue watch关于对象内的属性监听
2019/04/22 Javascript
微信小程序 云开发模糊查询实现解析
2019/09/02 Javascript
python中的__init__ 、__new__、__call__小结
2014/04/25 Python
Python的Django框架中模板碎片缓存简介
2015/07/24 Python
使用matplotlib画散点图的方法
2018/05/25 Python
Python turtle库绘制菱形的3种方式小结
2019/11/23 Python
Python 实现取多维数组第n维的前几位
2019/11/26 Python
购买200个世界上最好的内衣品牌:Bare Necessities
2017/02/11 全球购物
Yahoo-PHP面试题1
2016/07/20 面试题
护理自荐信
2013/10/22 职场文书
住房公积金接收函
2014/01/09 职场文书
信息技术教学反思
2014/02/12 职场文书
给老婆大人的检讨书
2014/02/24 职场文书
个人租房协议书
2014/04/09 职场文书
今冬明春火灾防控工作方案
2014/05/29 职场文书
幼儿教师师德师风演讲稿
2014/08/22 职场文书
2014学校领导四风对照检查材料思想汇报
2014/09/23 职场文书
《我爱祖国》演讲稿1000字
2014/09/26 职场文书
2015上半年个人工作总结
2015/07/27 职场文书
SpringBoot整合Redis入门之缓存数据的方法
2021/11/17 Redis
python数字图像处理之图像的批量处理
2022/06/28 Python