多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

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

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

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


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

以上這段代碼在網上很常見,通過設置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我想大家都看到了吧:)

出自:博客園

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 免费看的成人yellow视频 | 欧美日韩视频在线播放 | 在线播放人成午夜免费视频 | 九九九久久久 | 欧美一级毛片香蕉网 | 伊人影院综合在线 | 欧美日韩在线一区二区三区 | 在线免费黄色网址 | 国产亚洲人成在线影院 | 久久天天躁狠狠躁夜夜躁 | 毛片网站观看 | 亚洲大成色www永久网址 | 亚洲国产精品乱码一区二区三区 | 福利网站在线 | ady久久 | www久久com| 国产精品99久久免费黑人 | 亚洲欧美国产精品专区久久 | 午夜dj视频在线观看免费 | 日本久操 | 逼逼综合网 | 欧美一区二区视频在线观看 | 琪琪在线影院 | xxxxxx性受| 亚洲码在线观看 | 亚洲毛片网站 | 日产高清卡一卡二无卡三区 | 欧美人与动性视频在线观 | 一级做a爰片性色毛片中国 一级做a爰全过程免费视频毛片 | 成人精品美女隐私漫画 | 99久久精品毛片免费播放 | 亚洲黄色免费观看 | 日韩国产欧美 | 国产一区二区三区成人久久片 | 亚洲人人看 | 亚洲精品区一区二区三区四 | 男人都懂的www网站免费观看 | 亚洲春色综合另类小说 | 国产成人综合手机在线播放 | 欧美性videos高清另类hd | 欧美日本免费一区二区三区 |