千家信息网

css expression的用法及其优缺点介绍

发表于:2025-11-14 作者:千家信息网编辑
千家信息网最后更新 2025年11月14日,本篇文章为大家展示了css expression的用法及其优缺点介绍,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。概述css _expression(
千家信息网最后更新 2025年11月14日css expression的用法及其优缺点介绍

本篇文章为大家展示了css expression的用法及其优缺点介绍,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

概述
  css _expression(css表达式)又称Dynamic properties(动态属性)是早期微软DHTML的产物,以其可以在Css中定义表达式(公式)来达到建立元素间属性之间的联系等作用,从IE5开始得到支持,后因标准、性能、安全性等问题,微软从IE8 beta2标准模式开始,取消对css expression的支持。
使用
  微软提供了4个css expression方法:getExpression、recalc、removeExpression、setExpression。有兴趣可以参考msdn。
  一般最常用的是直接在css中使用expression,例如:

代码如下:


.toTop{
top:_expression(eval(document.documentElement.scrollTop + document.documentElement.clientHeight - 60)));
}


这是一个返回顶部按钮css代码的截取,用css来将元素定位到屏幕底部的位置。
优点
  css exprssion技术达到了可以使用表达式或公式来定义css属性的目的,msdn上给出了它的几个优点:减少页面上的代码,使设计师无需学习javascript就能实现一些DHTML的效果。个人认为,减少页面上的代码实际上只是减少了相关javascript的代码,而css expression中的代码本身与js是及其类似,设计师无需学习js就能实现DHTML效果这个优点也很牵强,或曰鸡肋。
缺陷
.不符合web标准
css表达式这种在表现(css)中插入行为(js)代码,有悖于web标准的结构、表现、行为相分离的理念。
.效率低下
一个css表达式会反复执行,甚至执行成百上千次。这会大大消耗计算机的硬件资源,极端情况下会导致浏览器的崩溃。
.带来安全隐患
css表达式暴露了一个脚本执行的上下文,可能带来脚本注入的隐患。
  基于以上原因,微软最终从IE8 beta2(标准模式下)开始放弃对css表达式的支持。
实际应用
  早期很多开发人员利用css expression实现了许多效果,比如将元素相对鼠标指针进行定位,根据一个定时器来移动元素等等。当然这些效果能够使用js来实现。
  虽然css表达式问题很多,但是我们依然能够在网上看到它们的影子,甚至在一些成熟的商业网站上。最常见的一个应用就是悬浮在页面上的某个模块(比如导航、返回顶部)。
  我们来看一个常见的返回顶部按钮的代码实现:
  html:

代码如下:




...

...

...
返回的顶部



 css:

代码如下:


#toTopBtn{
position:fixed;
bottom:10px;
right:10px;
_position:absolute;
_top:_expression(eval(document.documentElement.scrollTop + document.documentElement.clientHeight - 60));
...
}


_position和_top是对IE6的hack,因为IE6不支持position:fixed。这里的css表达式的作用是模拟position:fixed,即在将返回顶部按钮固定在页面的底部,不管页面是否滚动、缩放。正是因为css exprssion会执行多次,所以这个按钮元素才会一直定位在页面的底部。当然,我们可以使用javascript来模拟ie6的position:fixed,但细心的同学可能会发现这样一个问题,IE6下的返回顶部按钮会在你滚动页面的时候有较为明显的抖动。而我们使用css expression,这要在css加入以下规则,抖动的现象就会消失:

代码如下:


html{
_background-image:url(about/blank);
_background-attachment:fixed;
}


而使用js来模拟的,加上这句css规则也是没有效果的。这也应该是很多成熟商业网站现在还在使用css expression的原因。若有较好的实现方案,欢迎讨论。
  但是,根据YSlow提供的网页优化建议:Avoid CSS Expressions,也由于css expression的各种问题,个人不建议使用css表达式。可以和产品人员协商,容忍ie6下这点抖动的瑕疵,或者采用动画来美化这个抖动效果,或者使用另外的一种方式来实现position:fixed,比如:固定页面的高度,让页面内部的内容可滚动,然后将返回顶部按钮绝对定位到底部(采用这种实现方式要慎重,因为或对页面布局和结构造成较大的影响)。
  CSS expression作为web时代临时解决方案的产物,在被其创建者无情的抛弃后,我们更应该摈弃这种较为丑陋的代码方式,采用更优的解放方案。

上述内容就是css expression的用法及其优缺点介绍,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。

代码 表达式 页面 顶部 按钮 效果 元素 标准 问题 微软 定位 支持 优点 内容 属性 底部 方式 方案 优缺点 安全 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 松江区市场软件开发定制大概费用 东莞百意互联网科技 sas数据库提取多个变量 5g网络安全广告 网络安全与技术防火墙论文 服务器柜图 重庆生鲜软件开发哪家专业 超事通网络技术有限公司 小宇服务器管理工具 潜渊症找不到朋友服务器 企业网络安全海报收纳 网络技术春季高考山东有哪些学校 军区网络安全检查个人证件 西安软件开发岗位招聘信息 pubg登陆就显示服务器繁忙 计算机网络安全风险有哪些 服务器安装2008系统鼠标不动 数据块 索引 分布式数据库 月神殿服务器 玉环本地软件开发设备制造 幽冥传奇服务器需要什么配置 数据库改变量 成都科技公司软件开发工资多少 党员数据库是什么意思 软件开发审核思路 数据库表数据自己不断减少 网络安全评估与测试 常州堂品网络技术有限公司招聘 知识元建模用什么数据库 云计算信息网络技术有
0