日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > web前端 > htmlcss > 完美解決IE6不支持position:fixed的bug

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

來源:程序員人生   發布時間:2014-04-08 08:48:46 閱讀次數:2871次


提示:可修改后代碼再運行!

以上這段代碼在網上很常見,通過設置html{overflow:hidden}和body{height:100%;overflow:auto}來實現ie6下position:fixed效果,但這種辦法有個缺陷,那就是:這會使頁面上原有的absolute、relation都變成fixed的效果,在這里我就不做demo了,如果有懷疑,可以自己去試驗一下。

于是我找了下資料,發現可以通過一條Internet Explorer的CSS表達式(expression)來完美的實現ie6下position:fixed效果,css代碼如下:

/* 除IE6瀏覽器的通用方法 */
.ie6fixedTL{position:fixed;left:0;top:0}
.ie6fixedBR{position:fixed;right:0;bottom:0}
/* IE6瀏覽器的特有方法 */
* html .ie6fixedTL{position:absolute;left:expression(eval(document.documentElement.scrollLeft));top:expression(eval(document.documentElement.scrollTop))}
* html .ie6fixedBR{position:absolute;left:expression(eval(document.documentElement.scrollLeft+document.documentElement.clientWidth-this.offsetWidth)-(parseInt(this.currentStyle.marginLeft,10)||0)-(parseInt(this.currentStyle.marginRight,10)||0));top:expression(eval(document.documentElement.scrollTop+document.documentElement.clientHeight-this.offsetHeight-(parseInt(this.currentStyle.marginTop,10)||0)-(parseInt(this.currentStyle.marginBottom,10)||0)))}

上面代碼可以直接使用了,如果要設置元素懸浮邊距,要分別為設置兩次,比如我要讓某個元素距頂部10個像素,距左部也是10個像素,那就要這樣子寫:

/* 除IE6瀏覽器的通用方法 */
.ie6fixedTL{position:fixed;left:10px;top:10px}
/* IE6瀏覽器的特有方法 */
* html .ie6fixedTL{position:absolute;left:expression(eval(document.documentElement.scrollLeft+10));top:expression(eval(document.documentElement.scrollTop+10))}

這樣一來,IE6下實現position:fixed的效果解決了,而且也不會影響到其他的absolute、relation,但還有一個問題,就是懸浮的元素會出現振動

IE有一個多步的渲染進程。當你滾動或調整你的瀏覽器大小的時候,它將重置所有內容并重畫頁面,這個時候它就會重新處理css表達式。這會引起一個丑陋的“振動”bug,在此處固定位置的元素需要調整以跟上你的(頁面的)滾動,于是就會“跳動”。

解決此問題的技巧就是使用background-attachment:fixed為body或html元素添加一個background-image。這就會強制頁面在重畫之前先處理CSS。因為是在重畫之前處理CSS,它也就會同樣在重畫之前首先處理你的CSS表達式。這將讓你實現完美的平滑的固定位置元素!  然后我發現background-image無需一張真實的圖片,設置成about:blank就行了。

下面附上完整代碼

/* 除IE6瀏覽器的通用方法 */
.ie6fixedTL{position:fixed;left:0;top:0}
.ie6fixedBR{position:fixed;right:0;bottom:0}
/* IE6瀏覽器的特有方法 */
/* 修正IE6振動bug */
* html,* html body{background-image:url(about:blank);background-attachment:fixed}
* html .ie6fixedTL{position:absolute;left:expression(eval(document.documentElement.scrollLeft));top:expression(eval(document.documentElement.scrollTop))}
* html .ie6fixedBR{position:absolute;left:expression(eval(document.documentElement.scrollLeft+document.documentElement.clientWidth-this.offsetWidth)-(parseInt(this.currentStyle.marginLeft,10)||0)-(parseInt(this.currentStyle.marginRight,10)||0));top:expression(eval(document.documentElement.scrollTop+document.documentElement.clientHeight-this.offsetHeight-(parseInt(this.currentStyle.marginTop,10)||0)-(parseInt(this.currentStyle.marginBottom,10)||0)))}

至于demo我想大家都看到了吧:)

出自:博客園

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 国产精品一二区 | 国产精品视频999 | 特级a做爰全过程片 | 日韩一级黄色 | 欧美日韩不卡在线 | 国产日韩在线视频 | 国产精品3区 | 国产精品一区久久 | 国产在线一区二区三区 | 在线一区二区三区四区 | 超碰999 | 男的操女的视频 | 日韩高清在线观看 | 欧美在线视频一区二区 | 91重口变态 | 日韩欧美亚洲 | 精品久久影院 | 国产三级久久久 | 午夜激情视频在线观看 | 成人18视频| 91精品久久久久久久久青青 | 日韩精品视频在线 | 国产精品免费一区二区三区 | 毛片无码国产 | 99久久99视频 | 五月婷婷网 | 精品久久久一区二区 | 青青草综合在线 | 亚洲欧美综合一区二区 | 久久高清国产 | 亚洲一区二区三区在线看 | 性av在线 | heyzo久久| 久久亚洲国产视频 | 香港a毛片免费全部播放 | 国产一区二区在线免费观看 | 中文字幕日韩高清 | 日韩国产精品一区二区 | 日韩精品在线免费观看 | 久热久| 99在线精品免费视频 |