`
highfly-s
  • 浏览: 99844 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

IE6 position:fixed bug (固定窗口方法)

 
阅读更多

今天herb同 学在twitter上问到,如何利用CSS使搜索条固定显示于窗口的某个位置。好像之前也碰过这个问题,不过,当时并没有解决,用JS有现成的方法,不 过,这次要求的就是不用JS。然后,开始写代码,测试,最终,IE6下依然有问题。position:fixed;没有正常显示。

ie6 position:fixed bug

在别的文章中看到,可以用position:absolute;来解决IE6的问题,不过,添加position:absolute;之后,依然没 有成功。当然,最终,还是用position:absolute;来解决。只是,不一定能成功。因为,有一句非常重要的话需要理解。

 

以下是代码片段:[www.xlnv.net]

fixed元素的绝对位置是相对于HTML元素来说,滚动条是body元素的。(via,刚才竟然没找到来源,囧。)

只有记住了这句话,才知为什么position:absolute;很多地方都给出了结果,但当时并未能解决。因为html被我设置 position:relative。是上面这一句启发了我,最终才能够解决这个问题。我们拉动滚动条的时候,内容都会随着窗口滚动;这时滚动的是 body。如果让绝对定位的父级元素定为body,刚我们需要固定的某个模块将会固定在网页的某个位置,而不是固定在窗口的某个位置(貌似在 firefox中,html与body之间的介限并不明确?)。

我们需要做的是,让body保持其原有高度,让html只有一个窗口那么高。代码我们可以这样写:

以下是代码片段:[www.xlnv.net]
html{overflow:hidden;} // 重要!
body{height:100%;overflow:auto;}

 

这时,html将只有一个窗口那么高,超过的,直接hide。而body会随高度自动变化。这时,我们可以利用绝对定位来定位我们想要固定在窗口某个位置的模块。假设我们要固定的内容在右上角,代码可以这样写:

 

以下是代码片段:[www.xlnv.net]
html{overflow:hidden;}
body{height:100%;overflow:auto;}
#rightform form{position:absolute;right:30px;top50px;}

这样,窗口就固定在右上角了。而其他浏览器,我们可以用position:fixed;来解决固定的问题。其他浏览器完整的代码如下:

 

以下是代码片段:[www.xlnv.net]
#rightform {text-align:center;padding:50px;font:14px/22px Georgia, "Times New Roman", Times, serif;height:1200px;background:#ffc;}
#rightform h1 {font-family:arial;background:#e8edef;height:300px;line-height:300px;margin-bottom:200px;}
#rightform p {line-height:1.5em;background:#ffdfff;padding:90px 0;}
#rightform form {background-color:#ddd;padding:10px 20px;border:1px solid #aaa;position:fixed;right:30px;top:120px;}

 

HTML代码[www.xlnv.net]


[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]
 
转载自:http://www.cssdiy.com/Article/csshack/201104/1247.html
分享到:
评论

相关推荐

    IE6实现position:fixed bug (固定窗口方法)的实例

    这个内容是老生常谈了,主要问题就是IE6不支持 position:fixed 引起的BUG.当我们去搜索解决这个bug的垮浏览器解决办法时,绝大多数结果都是说使用 position:absolute 来替代解决,可是我们真的解决了么?没有,因为当页面...

    IE6不支持position:fixed bug的完美解决

    首先,让我们分析一下 IE6 中的 `position:fixed` bug。在标准浏览器中,设置 `position:fixed` 可以使元素相对于浏览器窗口定位,但在 IE6 中,这个属性会失效,导致元素的行为更像是 `position:absolute`,即相...

    IE6中的position:fixed定位兼容性写法分享

    在网页设计中,`position:fixed` 是一个 CSS 属性,用于设置元素的定位方式,使其相对于浏览器窗口保持固定,即使在滚动时也不会移动。然而,这个特性在 Internet Explorer 6 (IE6) 中存在一些兼容性问题。由于 IE6 ...

    js完美解决IE6不支持position:fixed的bug

    然而,IE6并不支持`position:fixed`,这给开发者带来了困扰。为了解决这个问题,我们需要采取一些特定的技巧。 首先,我们可以看到代码中使用了条件注释`<!--[if IE 6]>`来针对IE6应用特殊的CSS规则。常规的`...

    ie6 fixed bug的解决方法 (css+js)

    在IE6浏览器中,"fixed"定位是一个众所周知的bug,它无法像在现代浏览器中那样正常工作。"fixed"定位通常用于创建始终固定在视口某个位置的元素,如导航栏或悬浮窗口。然而,IE6并不支持CSS的"fixed"定位,导致元素...

    IE6 fixed的完美解决方案

    这段代码展示了如何利用CSS和JavaScript相结合的方式来解决IE6中position: fixed的不足,并提供了在垂直方向上固定元素的位置的示例。需要注意的是,这个解决方案主要解决了IE6在垂直方向上的fixed效果,如果需要在...

    IE6/7在滚动区域内的标签使用position会飘出这个滚动区域不随滚动条滚动

    `position`属性用于定义元素在页面上的定位方式,主要有`static`(默认值,正常流布局)、`relative`(相对定位,相对于其正常位置进行偏移)、`absolute`(绝对定位,相对于最近的非`static`定位祖先元素定位)和`...

    前端开发面试题整合(css、js、vue。react等)

    * fixed:固定定位,固定定位与父元素无关(无论父元素是否定位),直接根据浏览器窗口定位,且不随滚动条拖动页面而滚动,可以通过 z-index 进行层次分级。 2. 写出清除浮动影响的几种方法? 有三种方法可以清除...

    ExtAspNet v2.2.1 (2009-4-1) 值得一看

    -修正IE7下不能以下划线作为CSS中类名的前缀的BUG(feedback:Steve.Wei)。 -添加定时器控件Timer,用来定时发起AJAX请求。 +2009-09-06 v2.1.0 -Button的Pressed属性值能够正确的反映客户端的变化。 -优化...

    ExtAspNet_v2.3.2_dll

    -修正IE7下不能以下划线作为CSS中类名的前缀的BUG(feedback:Steve.Wei)。 -添加定时器控件Timer,用来定时发起AJAX请求。 +2009-09-06 v2.1.0 -Button的Pressed属性值能够正确的反映客户端的变化。 -优化...

    JavaScript Table行定位效果

    首先想到的方法是给tr设置relative,用ie6/7测试以下代码: Code <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> ...

    前端面试题汇总

    - IE6:`*expression` - IE7:`_expression` - IE8:`*+html expression` **22. 行内元素和块级元素的区别** - **行内元素**:在同一行内显示,不会独占一行。 - **块级元素**:默认独占一行,可以设置宽度和...

    javascript面试题

    此 bug 在 IE6 中较为常见,解决方法是在元素上添加 `_display: inline` 或使用其他 CSS Hack。 **41、HTML 与 XHTML —— 二者有什么区别?** - **HTML**:更加宽松的语法。 - **XHTML**:严格遵循 XML 规则,...

    HTML+CSS布局、规范、兼容

    IE6存在一个double-margin bug,可通过调整CSS来修复。 常用CSS属性方面,按照显示属性、盒模型属性、背景、行高、文本属性和其他属性来组织代码,可提高代码的可读性和易维护性。例如,在显示属性中包括display、...

    JS实现兼容性较好的随屏滚动效果

    - `fixed`:固定定位,相对于浏览器窗口进行定位,位置固定不会随滚动条移动。 在上述提供的代码片段中,通过`scroll`函数来动态地控制元素的位置属性。函数接收一个参数`p`,该参数包含了元素的ID和固定(`f`)...

Global site tag (gtag.js) - Google Analytics