91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

css怎么設置元素位置不變

發布時間:2020-12-11 14:09:23 來源:億速云 閱讀:184 作者:小新 欄目:web開發

這篇文章給大家分享的是有關css怎么設置元素位置不變的內容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。

css設置元素位置不變的方法:首先創建一個HTML示例文件;然后定義一個“#ads”的id樣式,并設置高度寬度;最后通過“position:fixed”以及right、bottom將元素定位在指定位置即可。

我們經常碰到的需求是希望頁面某個元素固定在瀏覽器的一個位置,無論如何滾動滾動條,位置不變,就例如經常看到的彈出廣告。方法一般是使用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;
}

我們定義一個#ads的id樣式,并給他設了高度寬度,通過position:fixed以及right、bottom將元素定位在窗口右下角。

使用position:fixed可以直接以瀏覽器窗口作為參考進行定位,它是浮動在頁面中,元素位置不會隨瀏覽器窗口的滾動條滾動而變化;除非你在屏幕中移動瀏覽器窗口的屏幕位置,或改變瀏覽器窗口的顯示大小,因此固定定位的元素會始終位于瀏覽器窗口內視圖的某個位置,不會受文檔流動影響。

但是在IE6下,并不支持position:fixed屬性,這個時候我們需要對IE6進行hack處理。解決的方案是使用 postion:absolute屬性,它的作用大家都很熟悉,相對于父元素進行絕對定位,然后我們可以通過expression來改變#ads的top 值。

PS expression的定義:IE5及其以后版本支持在CSS中使用expression,用來把CSS屬性和Javas cript 表達式關聯起來,這里的CSS屬性可以是元素固有的屬性,也可以是自定義屬性。就是說CSS屬性后面可以是一段Javas cript表達式,CSS屬性 的值等于Javas cript表達式計算的結果。 在表達式中可以直接引用元素自身的屬性和方法,也可以使用其他瀏覽器對象。這個表達式就好像是在這個 元素的一個成員函數中一樣。

所以我們可以通過在css里計算javascript值來改變top值,代碼如下:

#ads{
    _position:absolute;
    _top:expression(documentElement.scrollTop + 
            documentElement.clientHeight-this.offsetHeight);
}

似乎一切都完美了,但是我們在IE6下運行的時候會發現,隨著滾動條的移動,我們的這個#ads朋友他會抖動。解決方法也很簡單,只要在body里加一點點的css,如下:

body{
    background-image:url(about:blank); /* for IE6 */ 
    background-attachment:fixed; /*必須*/
}

好啦,完工!!!!!!!!!!!!!!!!!!!!!!!!

PS:原本使用的是"url(text.txt)",但是txt這個是不存在的,http請求報404錯誤,導致影響加載速度,參考了網上的一些寫法,使用about:blank可以達到相同目的。

原理據說是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;
}

感謝各位的閱讀!關于css怎么設置元素位置不變就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

css
AI

华坪县| 义马市| 平江县| 华阴市| 聂荣县| 四川省| 江都市| 和龙市| 边坝县| 古田县| 准格尔旗| 临沧市| 余江县| 长子县| 衡阳县| 泾源县| 鹤峰县| 金堂县| 麻阳| 尚义县| 上高县| 宜州市| 黄梅县| 马山县| 凭祥市| 雷波县| 子长县| 万州区| 荆州市| 镇赉县| 七台河市| 凤城市| 丹凤县| 广饶县| 涡阳县| 伊金霍洛旗| 若羌县| 万安县| 甘肃省| 普陀区| 崇阳县|