這篇文章給大家分享的是有關(guān)css怎么設(shè)置元素位置不變的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過來看看吧。
10多年的那曲網(wǎng)站建設(shè)經(jīng)驗(yàn),針對設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。成都營銷網(wǎng)站建設(shè)的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整那曲建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)從事“那曲網(wǎng)站設(shè)計(jì)”,“那曲網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
css設(shè)置元素位置不變的方法:首先創(chuàng)建一個(gè)HTML示例文件;然后定義一個(gè)“#ads”的id樣式,并設(shè)置高度寬度;最后通過“position:fixed”以及right、bottom將元素定位在指定位置即可。
我們經(jīng)常碰到的需求是希望頁面某個(gè)元素固定在瀏覽器的一個(gè)位置,無論如何滾動滾動條,位置不變,就例如經(jīng)常看到的彈出廣告。方法一般是使用js控制,或者使用css。這里我寫的是css的控制方法。
在IE7以上版本及firefox、opera、safari里,都支持css屬性"position:fixed",它的作用就是將元素相對于窗口固定位置。代碼如下
#ads{ position:fixed; right:0; bottom:0; border:1px solid red; width:300px; height:250px; }
我們定義一個(gè)#ads的id樣式,并給他設(shè)了高度寬度,通過position:fixed以及right、bottom將元素定位在窗口右下角。
使用position:fixed可以直接以瀏覽器窗口作為參考進(jìn)行定位,它是浮動在頁面中,元素位置不會隨瀏覽器窗口的滾動條滾動而變化;除非你在屏幕中移動瀏覽器窗口的屏幕位置,或改變?yōu)g覽器窗口的顯示大小,因此固定定位的元素會始終位于瀏覽器窗口內(nèi)視圖的某個(gè)位置,不會受文檔流動影響。
但是在IE6下,并不支持position:fixed屬性,這個(gè)時(shí)候我們需要對IE6進(jìn)行hack處理。解決的方案是使用 postion:absolute屬性,它的作用大家都很熟悉,相對于父元素進(jìn)行絕對定位,然后我們可以通過expression來改變#ads的top 值。
PS expression的定義:IE5及其以后版本支持在CSS中使用expression,用來把CSS屬性和Javas cript 表達(dá)式關(guān)聯(lián)起來,這里的CSS屬性可以是元素固有的屬性,也可以是自定義屬性。就是說CSS屬性后面可以是一段Javas cript表達(dá)式,CSS屬性 的值等于Javas cript表達(dá)式計(jì)算的結(jié)果。 在表達(dá)式中可以直接引用元素自身的屬性和方法,也可以使用其他瀏覽器對象。這個(gè)表達(dá)式就好像是在這個(gè) 元素的一個(gè)成員函數(shù)中一樣。
所以我們可以通過在css里計(jì)算javascript值來改變top值,代碼如下:
#ads{ _position:absolute; _top:expression(documentElement.scrollTop + documentElement.clientHeight-this.offsetHeight); }
似乎一切都完美了,但是我們在IE6下運(yùn)行的時(shí)候會發(fā)現(xiàn),隨著滾動條的移動,我們的這個(gè)#ads朋友他會抖動。解決方法也很簡單,只要在body里加一點(diǎn)點(diǎn)的css,如下:
body{ background-image:url(about:blank); /* for IE6 */ background-attachment:fixed; /*必須*/ }
好啦,完工!?。。。。。。。。。。。。。。。。。。。。。?!
PS:原本使用的是"url(text.txt)",但是txt這個(gè)是不存在的,http請求報(bào)404錯(cuò)誤,導(dǎo)致影響加載速度,參考了網(wǎng)上的一些寫法,使用about:blank可以達(dá)到相同目的。
原理據(jù)說是ie6不支持fixed 而其樣式背景卻支持fixed,通過背景來此消彼長消除抖動,望大牛指教。
完整的代碼:
body{ background-image:url(about:blank); /* for IE6 */ background-attachment:fixed; /*必須*/ } #ads{ width:300px; height:250px; position:fixed; right:0; bottom:0; _position:absolute; _top:expression(documentElement.scrollTop + documentElement.clientHeight-this.offsetHeight); border:1px solid red; }
感謝各位的閱讀!關(guān)于css怎么設(shè)置元素位置不變就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!