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 相关文章推荐
Save a File Using a File Save Dialog Box
Jun 18 Javascript
Javascript面向对象编程
Mar 18 Javascript
js如何获取file控件的完整路径具体实现代码
May 15 Javascript
js实现拉伸拖动iframe的具体代码
Aug 03 Javascript
js中for in的用法示例解析
Dec 25 Javascript
使用jQuery快速解决input中placeholder值在ie中无法支持的问题
Jan 02 Javascript
jQuery的$.proxy()应用示例介绍
Apr 03 Javascript
使用Jasmine和Karma对AngularJS页面程序进行测试
Mar 05 Javascript
详解mpvue中使用vant时需要注意的onChange事件的坑
May 16 Javascript
在LayUI图片上传中,解决由跨域问题引起的请求接口错误的方法
Sep 24 Javascript
Centos7 安装Node.js10以上版本的方法步骤
Oct 15 Javascript
原生js实现弹窗消息动画
Nov 20 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
PHP 读取文件内容代码(txt,js等)
2009/12/06 PHP
使用ThinkPHP自带的Http类下载远程图片到本地的实现代码
2011/08/02 PHP
浅谈web上存漏洞及原理分析、防范方法(文件名检测漏洞)
2013/06/29 PHP
php读取csv实现csv文件下载功能
2013/12/18 PHP
php日历制作代码分享
2014/01/20 PHP
JavaScript中的6种运算符总结
2014/10/16 Javascript
node.js中的fs.appendFile方法使用说明
2014/12/17 Javascript
js实现带按钮的上下滚动效果
2015/05/12 Javascript
JavaScript Split()方法
2015/12/18 Javascript
JavaScript提高性能知识点汇总
2016/01/15 Javascript
jQuery代码实现表格中点击相应行变色功能
2016/05/09 Javascript
JavaScript中两个字符串的匹配
2016/06/08 Javascript
全面了解JavaScript的数据类型转换
2016/07/01 Javascript
基于SpringMVC+Bootstrap+DataTables实现表格服务端分页、模糊查询
2016/10/30 Javascript
Validform表单验证总结篇
2016/10/31 Javascript
Bootstrap框架安装使用详解
2017/01/21 Javascript
Angularjs分页查询的实现
2017/02/24 Javascript
Angular 4依赖注入学习教程之组件服务注入(二)
2017/06/04 Javascript
Angularjs 根据一个select的值去设置另一个select的值方法
2018/08/13 Javascript
VuePress 静态网站生成方法步骤
2019/02/14 Javascript
利用JavaScript的Map提升性能的方法详解
2019/08/14 Javascript
[01:08:33]OG vs VGJ.T 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
老生常谈Python之装饰器、迭代器和生成器
2017/07/26 Python
python利用urllib实现爬取京东网站商品图片的爬虫实例
2017/08/24 Python
matplotlib绘图实例演示标记路径
2018/01/23 Python
使用python中的in ,not in来检查元素是不是在列表中的方法
2018/07/06 Python
python批量下载抖音视频
2019/06/17 Python
python由已知数组快速生成新数组的方法
2020/04/08 Python
浅谈Python 参数与变量
2020/06/20 Python
Finishline官网:美国一家领先的运动品牌鞋类、服装零售商
2016/07/20 全球购物
大学生毕业自我鉴定范文
2013/11/03 职场文书
2014年信息宣传工作总结
2014/12/18 职场文书
2014年加油站站长工作总结
2014/12/23 职场文书
个人求职自荐信范文
2015/03/06 职场文书
2015年学校禁毒工作总结
2015/05/27 职场文书
生死牛玉儒观后感
2015/06/11 职场文书