您现在的位置是:网站首页> 编程资料编程资料
CSS行为expression轻松实现IE6无抖动固定定位CSS expression判断表达式设置input样式CSS expression在Chrome的问题优化浏览器渲染 避免CSS expressionsCSS中使用expression完美设置页面最小宽度(兼容ie)css expression使用概述及其优缺点介绍CSS表达式(expression)解决IE6 position:fixed无效问题CSS中使用expression表达式
2023-10-26
215人已围观
简介 IE6不支持固定定位(position:fixed)是众所周知的事情,想在IE6做出固定定位的效果就只能用JS,用js会出现“跳动”的效果,下面为大家介绍下CSS中的行为expression
概述:
IE6不支持固定定位(position:fixed)是众所周知的事情,所以我们要想在IE6做出固定定位的效果就只能用JS,但是用js会出现“跳动”的效果,所以有没有不用JS而且不跳动的办法呢?这是怎么做到的呢?今天说说CSS中的行为expression。
什么是行为-expression:
就是CSS属性后面可以是一段JS表达式,CSS属性的值等于JS表达式计算的结果。在表达式中可以直接引用元素自身的属性和方法,也可以使用其他浏览器对象。这个表达式就好像是在这个元素的一个成员函数中一样。
为什么使用行为(expression)能解决问题:
因为CSS中使用expression只有IE才能识别。
实现方法:
在css中写入js代码:
#backtop{
width: 40px;
height: 45px;
position:fixed;
right: 0px;
bottom: 10px;
z-index: 9;
//针对IE6
_position:absolute;
_top:expression(eval(document.documentElement.scrollTop + 430));
border: none;
overflow:hidden;
}
这样一个,固定定位的问题解决了,但是还有问题,元素会跳动,这是为什么
IE6中的元素为什么会跳动的:
这是因为IE有一个多步的渲染进程。当你滚动或调整你的浏览器大小的时候,它将重置所有内容并重画页面,这个时候它就会重新处理css表达式,但是这是DOM结构是先于CSS展示出来,所以这会引起一个"抖动"bug,在此处固定位置的元素需要调整以跟上你的(页面)滚动,于是就会跳动,解决此问题的技巧就是使用background-attachment:fixed为body或html元素添加一个background-image。这就会强制页面在重画之前先处理css。因为是在重画之前处理CSS,它也就会同样在重画之前首先处理你的css表达式。这将让你实现完美的平滑的固定位置元素!然后我发现background-image无需一张真实的图片,设置成about:blank就行。
元素跳动的解决方法:
body {
//针对IE6在重画之前处理CSS
_background: url(about:blank);
_background-attachment: fixed;
}
IE6不支持固定定位(position:fixed)是众所周知的事情,所以我们要想在IE6做出固定定位的效果就只能用JS,但是用js会出现“跳动”的效果,所以有没有不用JS而且不跳动的办法呢?这是怎么做到的呢?今天说说CSS中的行为expression。
什么是行为-expression:
就是CSS属性后面可以是一段JS表达式,CSS属性的值等于JS表达式计算的结果。在表达式中可以直接引用元素自身的属性和方法,也可以使用其他浏览器对象。这个表达式就好像是在这个元素的一个成员函数中一样。
为什么使用行为(expression)能解决问题:
因为CSS中使用expression只有IE才能识别。
实现方法:
在css中写入js代码:
复制代码
代码如下:#backtop{
width: 40px;
height: 45px;
position:fixed;
right: 0px;
bottom: 10px;
z-index: 9;
//针对IE6
_position:absolute;
_top:expression(eval(document.documentElement.scrollTop + 430));
border: none;
overflow:hidden;
}
这样一个,固定定位的问题解决了,但是还有问题,元素会跳动,这是为什么
IE6中的元素为什么会跳动的:
这是因为IE有一个多步的渲染进程。当你滚动或调整你的浏览器大小的时候,它将重置所有内容并重画页面,这个时候它就会重新处理css表达式,但是这是DOM结构是先于CSS展示出来,所以这会引起一个"抖动"bug,在此处固定位置的元素需要调整以跟上你的(页面)滚动,于是就会跳动,解决此问题的技巧就是使用background-attachment:fixed为body或html元素添加一个background-image。这就会强制页面在重画之前先处理css。因为是在重画之前处理CSS,它也就会同样在重画之前首先处理你的css表达式。这将让你实现完美的平滑的固定位置元素!然后我发现background-image无需一张真实的图片,设置成about:blank就行。
元素跳动的解决方法:
复制代码
代码如下:body {
//针对IE6在重画之前处理CSS
_background: url(about:blank);
_background-attachment: fixed;
}
相关内容
- 纯CSS3实现鼠标悬停提示气泡效果CSS3 仿微信聊天小气泡实例代码HTML5-WebSocket实现聊天室示例HTML5仿手机微信聊天界面纯CSS实现聊天框小尖角、气泡效果利用html5的websocket实现websocket聊天室纯CSS实现右侧底部悬浮效果(悬浮QQ、微信、微博、邮箱等联系方式)如何弹出QQ临时对话框实现不添加好友在线交谈效果CSS3制作气泡对话框的实例教程可自定义箭头样式的CSS3气泡提示框利用CSS3实现气泡效果的教程
- 我叫MT3月20日例行维护时间和维护内容介绍_手机游戏_游戏攻略_
- 腾讯雷霆战机3月20日维护更新时间和充值补偿公告_手机游戏_游戏攻略_
- 《卡利戈猎人》武器合成条件_手机游戏_游戏攻略_
- 腾讯雷霆战机无尽模式BOSS红色重装机怎么过_手机游戏_游戏攻略_
- 《史上最难的游戏2 The Hardest Escape 2》图文攻略_手机游戏_游戏攻略_
- 天天酷跑3月20破解版最新刷分亲测无异常 叉叉助手修改教程攻略_手机游戏_游戏攻略_
- 天天酷跑账号被封怎么解决 天天酷跑账号解封教程推荐_手机游戏_游戏攻略_
- 天天酷跑新手攻略及高手进阶教程_手机游戏_游戏攻略_
- 天天酷跑破解版最强档极限刷分攻略推荐 永不和谐勇创高峰_手机游戏_游戏攻略_
