我在某处读到CSS表达式已被弃用,甚至不应该使用。我从来没有听说过他们,所以我决定去看看。我发现了一个代码示例,它将一个浮动元素保留在屏幕上的同一位置,即使您滚动。
<html>
<style>
#fixed {
position:absolute;
left:10px;
top:expression(body.scrollTop + 50 + "px");
background:white;
border:1px solid red;}
</style>
<body>
<p id="fixed">Here is some text, which is fixed.</p>
<p>
[many times: "stuff <br/>"]
</p>
</body>
</html>
这让我想起了那些在页面底部有“分享条”之类的东西的网站。
所以..。
发布于 2011-06-01 02:13:22
CSS表达式过去可以在旧的IE中使用,但它们已经被completely abandoned in IE8:了
在IE8标准模式和更高版本中,Internet Explorer8和更高版本不再支持
动态属性(也称为"CSS表达式“)。此决定是出于符合标准、浏览器性能和安全原因而做出的,如标题为Ending Expression的IE博客条目中所述。在Internet Explorer8中,动态属性在IE7模式或IE5模式下仍然可用。
因此,可以说不值得再学习它们了。
如果没有,我应该使用什么?
根据使用情形,可以选择JavaScript或media queries。
正如@Yet Another Geek所说,上面的例子可以使用position: fixed
实现。IE6不支持这一点-- CSS表达式可能就是为了解决这个问题而创建的。
发布于 2011-06-01 02:15:59
为了使元素在滚动时保持在同一位置,您应该使用position:fixed属性,然后使用top、bottom、left和right属性来确定它应该放置的位置。
编辑:下面是你的例子应该是什么样子:
<html>
<style>
#fixed {
position:fixed;
left:10px;
top: 50px;
background:white;
border:1px solid red;}
</style>
<body>
<p id="fixed">Here is some text, which is fixed.</p>
<p>
[many times: "stuff <br/>"]
</p>
</body>
</html>
发布于 2011-06-01 02:17:14
position:fixed
或Javascriptposition:fixed; bottom:x; top:y; left: a; right:b;
,其中x,y,a和b是偏移量。或者,除非你只使用旧版本的IE,否则不要使用Javascript*无论如何,都是正式的。显然,它在@DalexL的Chrome上工作正常
https://stackoverflow.com/questions/6191679
复制相似问题