摘要:和屬性數值對應的是元素的內容加所占據的視覺面積,有滾動條時還要加上滾動條,不含。和仍要分有沒有滾動,有滾動時指的是整個頁面內容的大小沒滾動時在下指視口的大小和下則是和一樣。與屬性在下都和原來一樣指整個元素的可視寬高。
光標效果不見了?
在頁面里,屏幕上光標的樣式我們可以用css的"cursor"屬性進行定義。一般來講,只要光標hover到指定的元素上面其樣式就會按我們指定的進行顯示,但是如果我們指定的元素被其他元素“遮住了”呢?來看看下面這個demo:
demo
可以看到,雖然我們給div1自定義了光標樣式,但在被div2蓋住的那部分,我們預設的效果就沒有了,或者說這個效果是不能“穿透”div2的。這也就提示我們,當我們的一些交互需要我們自定義光標樣式的時候(比如拖動),一定要注意元素間的堆疊順序,否則很有可能會出現你移動到某個位置上時你的光標效果突然消失的現象。
至于css本身是如何決定元素間堆疊順序的,這還是個比較復雜的問題,具體地可以看看張鑫旭這篇文章。
js里幾個獲取元素寬高屬性的比較offsetWidth、clientWidth、scrollWidth、offsetHeight、clientHeight、scrollHeight這幾個屬性的特點一直傻傻分不清,這次就好好把他們弄清楚吧。先看demo:
demo
先分析一下div1和待滾動條的div2兩個普通元素的情況,在不同瀏覽器下(不考慮IE8-)運行上面這個demo后,在控制臺可以看到各瀏覽器的結果都是一樣的:
可以得出結論:
offsetWidth和offsetHeight屬性:數值對應的是元素的可視寬高,含元素本身寬高、padding、(有滾動條時)滾動條、border。
clientHeight和clientWidth屬性:數值對應的是元素的內容加padding所占據的視覺面積,有滾動條時還要加上滾動條,不含border。
scrollHeight和scrollWidth屬性:由div1的結果可見,沒有滾動條時執行結果和clientHeight、clientWidth一樣。有滾動條的情況則復雜一點,上面這個例子中div2的內容足夠大、能產生滾動,故此時結果為content的大小;而如果把content這個div調小、直到不能產生滾動時結果應該是和clientHeight、clientWidth一樣的。
上面的結論只是針對頁面普通元素,如果使用這幾個屬性的是整個頁面(html元素,這里用document.documentElement訪問),那輸出的情況就復雜了,沒有明顯的規律,找的不同的資料說法也不太相同、并不能解釋我測試的結果。所以這里只講一些我測試之后比較固定的結果,僅供參考:
首先clientHeight和clientWidth的行為普通元素的不太一樣,在所有瀏覽器里基本指的都是頁面視口的大小。
scrollHeight和scrollWidth仍要分有沒有滾動,有滾動時指的是整個頁面內容的大小;沒滾動時在chrome下指視口的大小、IE和FF下則是和offsetWidth、offsetHeight一樣。
offsetWidth與offsetHeight屬性在chrome、FF、IE11下都和原來一樣指整個元素的可視寬高。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/115087.html
摘要:和并不是一個標準的屬性,才是,所以火狐長久以來都不支持,同時也不支持。 這個系列保持開坑不埋的狀態已經過去三個月了,而在這幾個月中我才算第一次認真地深入理解js。雖然期間筆記是記了不少,但寫博文又不應是簡單的復制粘貼,還是得保證有討論價值、有干貨的。而我面對的現實是:一來基礎差導致識別和撈出有討論價值的干貨得自身功夫練到一定階段,二來又因為記的雜亂且缺乏日常整理,整理一下就是拖一下,再...
閱讀 3054·2021-11-22 15:29
閱讀 1731·2021-10-12 10:11
閱讀 1758·2021-09-04 16:45
閱讀 2240·2021-08-25 09:39
閱讀 2793·2021-08-18 10:20
閱讀 2516·2021-08-11 11:17
閱讀 450·2019-08-30 12:49
閱讀 3313·2019-08-30 12:49