javascript与CSS复习(二)


Posted in Javascript onJune 29, 2010

visibility:在切换元素可见性的同时会保持元素在普通流中的位置和空间。它有两个值:visible(默认的)和hidden(不可见的),
例如:

<p>Hello <b>John</b>, how are you today?</p>

浏览器中是:Hello John, how are you today? 接着我们把John所在b的visibility设置为hidden后,就会变成这样
Hello , how are you today?
display:为我们控制元素的布局提供了更丰富的选择。可以是inline、block或是none(它完全从文档中隐藏了元素,结果跟从文档中删除了该元素的情形看起来一样)。还是上面的例子,如果我们用了display:none。那么结果是
Hello , how are you today?
下面给出书中两个简单函数用于显示和隐藏元素
//使用display隐藏元素 
function hide(elem) { 
//找出元素display的当前状态 
var curDisplay = getStyle(elem, 'display'); 
//记录它的display状态 
if(curDisplay != 'none') 
elem.$oldDisplay = curDisplay; 
//设置display为none 
elem.style.display = 'none'; 
} 
//使用display显示元素 
function show(elem) { 
//设置display属性为它的原始值 
elem.style.display = elem.$oldDisplay || ' '; 
}

接下来我们来研究下透明度opacity,这可以给元素添加一个很cool的效果...看下下面这个设置元素透明度的函数。
//设置元素的透明度(级别从0-100) 
function setOpacity(elem, level) { 
//如果存在filters这个属性,则它是IE 
if(elem.filters) { 
elem.style.filters = 'alpha(opacity=' + level + ')'; 
} else { //否则,使用W3C的opacity属性 
elem.style.opacity = level / 100; 
} 
}

有了这些调整元素位置、尺寸和可见性的方法,我们就能把它们结合起来创建动画。
function slideDown(elem) { 
//从0高度开始滑动 
elem.style.height = '0px'; 
//先显示元素(但是看不到它,因为它的高度为0) 
show(elem); 
//找到元素的完整的潜在高度 
var h = fullHeight(elem); 
//我们在1秒钟内执行一个20帧的动画 
for(var i = 0; i <= 100; i += 5) { 
//保证我们能够保持正确的'i'的闭包函数 
(function() { 
var pos = i; 
//设置timeout以让它能在指定的时间点运动 
setTimeout(function() { 
//设置元素新的高度 
elem.style.height = (pos / 100) * h + 'px'; 
}, (pos + 1) * 10); 
})(); 
} 
}

这里有个闭包的概念,理解起来可能有些难度,感兴趣深入的园友可以去Google下,这里就不多讨论了。
接下来用setOpacity函数写个"渐显"函数:
function fadeIn(elem) { 
//从0透明度开始 
setOpacity(elem, 0); 
//先显示元素(但是看不到它,因为它的透明度是0) 
show(elem); 
//我们在1秒钟内执行一个20帧的动画 
for(var i = 0; i < 100; i += 5) { 
//保证我们能够保持正确的'i'的闭包函数 
(function(){ 
var pos = i; 
//设置timeout以让它能在指定的事件内运行 
setTimeout(function() { 
setOpacity(elem, pos); 
}, (pos + 1) * 10); 
})(); 
} 
}

为了代码的正确性,我写完后都去测试一下,因为发现书中会有些小错误,刚测试完上面的slideDown方法,应该把var h = fullHeight(elem);放到函数内容的第一句,不然没效果....
第二部分的复习就到这里,慢慢消化,学东西可不能急于求成哦。
Javascript 相关文章推荐
jQuery使用动态渲染表单功能完成ajax文件下载
Jan 15 Javascript
了解了这些才能开始发挥jQuery的威力
Oct 10 Javascript
js限制input标签中只能输入中文
Jun 26 Javascript
javascript基本语法
May 31 Javascript
全面解析Angular中$Apply()及$Digest()的区别
Aug 04 Javascript
纯JS实现可拖拽表单的简单实例
Sep 02 Javascript
js 输入框 正则表达式(菜鸟必看教程)
Feb 19 Javascript
分享vue.js devtools遇到一系列问题
Oct 24 Javascript
重新认识vue之事件阻止冒泡的实现
Aug 02 Javascript
在微信小程序里使用watch和computed的方法
Aug 02 Javascript
在 Vue 中使用 JSX 及使用它的原因浅析
Feb 10 Javascript
解决ant-design-vue中menu菜单无法默认展开的问题
Oct 31 Javascript
javascript与CSS复习(《精通javascript》)
Jun 29 #Javascript
通过javascript的匿名函数来分析几段简单有趣的代码
Jun 29 #Javascript
JavaScript 联动的无限级封装类,数据采用非Ajax方式,随意添加联动
Jun 29 #Javascript
Whatever:hover 无需javascript让IE支持丰富伪类
Jun 29 #Javascript
javascript hasFocus使用实例
Jun 29 #Javascript
jquery photoFrame 图片边框美化显示插件
Jun 28 #Javascript
使用jQuery.Validate进行客户端验证(初级篇) 不使用微软验证控件的理由
Jun 28 #Javascript
You might like
Zend引擎的发展 [15]
2006/10/09 PHP
PHP strtr() 函数使用说明
2008/11/21 PHP
php使用百度天气接口示例
2014/04/22 PHP
PHP实现的分页类定义与用法示例
2017/07/05 PHP
TP5(thinkPHP5框架)基于bootstrap实现的单图上传插件用法示例
2019/05/29 PHP
根据地区不同显示时间的javascript代码
2007/08/13 Javascript
JavaScript中的16进制字符(改进)
2011/11/21 Javascript
javascript:history.go()和History.back()的区别及应用
2012/11/25 Javascript
原生js实现fadein 和 fadeout淡入淡出效果
2014/06/05 Javascript
this,this,再次讨论javascript中的this,超全面(经典)
2016/01/05 Javascript
JavaScript队列的应用实例详解【经典数据结构】
2017/04/12 Javascript
VueJS事件处理器v-on的使用方法
2017/09/27 Javascript
去掉vue 中的代码规范检测两种方法(Eslint验证)
2018/03/21 Javascript
详解Angular5/Angular6项目如何添加热更新(HMR)功能
2018/10/10 Javascript
jquery分页插件pagination使用教程
2018/10/23 jQuery
JavaScript实现秒杀时钟倒计时
2019/09/29 Javascript
用VsCode编辑TypeScript的实现方法
2020/05/07 Javascript
uniapp实现可滑动选项卡
2020/10/21 Javascript
Vue+penlayers实现多边形绘制及展示
2020/12/24 Vue.js
django的登录注册系统的示例代码
2018/05/14 Python
Python面向对象程序设计类变量与成员变量、类方法与成员方法用法分析
2019/04/12 Python
python实现知乎高颜值图片爬取
2019/08/12 Python
Pytorch实现GoogLeNet的方法
2019/08/18 Python
详解Django自定义图片和文件上传路径(upload_to)的2种方式
2020/12/01 Python
静态成员和非静态成员的区别
2012/05/12 面试题
社区优秀志愿者材料
2014/02/02 职场文书
优秀实习生感言
2014/03/01 职场文书
入党积极分子学习两会心得体会范文
2014/03/17 职场文书
拾金不昧表扬信怎么写
2015/05/04 职场文书
2015年中学体育教师工作总结
2015/10/23 职场文书
积极心理学课程心得体会
2016/01/22 职场文书
解析Redis Cluster原理
2021/06/21 Redis
《艾尔登法环》发布最新「战技」宣传片
2022/04/03 其他游戏
全新239军机修复记
2022/04/05 无线电
Android自定义双向滑动控件
2022/04/19 Java/Android
Pygame游戏开发之太空射击实战敌人精灵篇
2022/08/05 Python