關于HTML中的滾動條/去掉滾動條問題
來源:易賢網(wǎng) 閱讀:770 次 日期:2016-06-16 11:50:08
溫馨提示:易賢網(wǎng)小編為您整理了“關于HTML中的滾動條/去掉滾動條問題”,方便廣大網(wǎng)友查閱!

1.xhtml下滾動條的顏色問題

在原來的html的時候,我們可以這樣定義整個頁面的滾動條:

代碼如下:

body{

scrollbar-3dlight-color:#D4D0C8; /*- 最外左 -*/

scrollbar-highlight-color:#fff; /*- 左二 -*/

scrollbar-face-color:#E4E4E4; /*- 面子 -*/

scrollbar-arrow-color:#666; /*- 箭頭 -*/

scrollbar-shadow-color:#808080; /*- 右二 -*/

scrollbar-darkshadow-color:#D7DCE0; /*- 右一 -*/

scrollbar-base-color:#D7DCE0; /*- 基色 -*/

scrollbar-track-color:#;/*- 滑道 -*/

}

但是同樣的代碼,我們應用在 xhtml下就不起作用了,我相信好多好朋友也遇到過同樣的問題。

那么怎么才能在xhtml下應用滾動條樣式呢?看下列代碼:

代碼如下:

html{

scrollbar-3dlight-color:#D4D0C8; /*- 最外左 -*/

scrollbar-highlight-color:#fff; /*- 左二 -*/

scrollbar-face-color:#E4E4E4; /*- 面子 -*/

scrollbar-arrow-color:#666; /*- 箭頭 -*/

scrollbar-shadow-color:#808080; /*- 右二 -*/

scrollbar-darkshadow-color:#D7DCE0; /*- 右一 -*/

scrollbar-base-color:#D7DCE0; /*- 基色 -*/

scrollbar-track-color:#;/*- 滑道 -*/

}

這段代碼和上一段唯一的不同就是在css定義的元素上,一個是body一個是html。我們再測試一下,把html頁面的“body”修改成“html”測試一下,發(fā)現(xiàn)依然可以實現(xiàn)效果。那到底是為什么呢?

我們來看一下下面的圖:

這就是html最基本的dom樹結構。

我們再看看html和xhtml的定義:

HTML (Hyper Text Markup Language,超文件標記語言),超文件標記語言廣泛應用于國際互聯(lián)網(wǎng)上.HTML描述了文本基準如何進行呈現(xiàn),以及超級連接如何連接到另外的頁面。

XHTML (Extensible Hypertext Markup Language,可擴展的超文件標記語言),是一種標記語言,表現(xiàn)方式與 HTML類似, 不過語法上更加嚴格。從繼承關系上講,HTML是一種基于SGML的應用,非常靈活,而XHTML則基于XML,XML是SGML的一個子集。XHTML 1.0 在2000年1月26日成為 W3C 的推薦標準。

從字面上來看,xhtml比html多一個x,那么這個x其實也就是xml,為什么要加一個xml在里面?其實最根本的原因就是要讓html更加結構化標準化(因為html實在是太爛)。

OK,我們回來看上面的結構樹,我們在html里面定義的是body,因為html不是很標準所以這樣可以生效,而在xhtml里面這樣就不行了,我看看那個圖很明顯,body標簽本身不是根元素,只有html才是根元素,而頁面的滾動條也是屬于根元素的,所以這就是我們?yōu)槭裁炊xbody沒有效果的原因,因為我們定義的只是一個子原素。OK,我們知道了原理,來做一個試驗如果把定義“body”或“xhtml”換成“*”:

代碼如下:

*{

scrollbar-3dlight-color:#D4D0C8; /*- 最外左 -*/

scrollbar-highlight-color:#fff; /*- 左二 -*/

scrollbar-face-color:#E4E4E4; /*- 面子 -*/

scrollbar-arrow-color:#666; /*- 箭頭 -*/

scrollbar-shadow-color:#808080; /*- 右二 -*/

scrollbar-darkshadow-color:#D7DCE0; /*- 右一 -*/

scrollbar-base-color:#D7DCE0; /*- 基色 -*/

scrollbar-track-color:#;/*- 滑道 -*/

}

在html和xhtml都通過,因為*就是定義頁面上的任何標簽當然也包括了“html”這個標簽。

(ps:其實與其說是html與xhtml的區(qū)別到不如說是有無XHTML 1.0 transitional doctype的區(qū)別,但是如果你把頁面的XHTML 1.0 transitional doctype去掉的話,那么這個頁面就沒有doctype,默認的顯示方式就是html4.01,不過你要把XHTML 1.0 transitional doctype修改成HTML 4.01 doctype同樣頁面定義body也不會有效果的,雖然這個頁面的標準是html 4.01)

2、xhtml下frame頁面橫向滾動條的問題

在用ie6瀏覽有框架的xhtml頁面的時候,默認會水平和垂直滾動條會一起出現(xiàn),這是ie6的一個bug,在firefox上是正常的,出現(xiàn)的原因是其對XHTML 1.0 transitional doctype的解釋缺陷。

對于這個bug一般有3種解決方案,

方法1:

代碼:

html { overflow-y: scroll; }

原理:強制顯示ie的垂直滾動條,而忽略水平滾動條。

優(yōu)點:完全解決了這個問題, 允許你保持完整的XHTML doctype 。

缺點:即使頁面不需要垂直滾動條的時候也會出現(xiàn)垂直滾動條。

方法2:

代碼:

html { overflow-x: hidden; overflow-y: auto; }

原理:隱藏橫向滾動,垂直滾動根據(jù)內容自適應。

優(yōu)點:在視覺上解決了這個問題。在不必要的時候,未強制垂直滾動條出現(xiàn)。

缺點:只是隱藏了水平滾動條,如果頁面真正需要水平滾動條的時候,屏幕以外的內容會因為用戶無法水平滾動,而看不到。

方法3:

代碼:

body { margin-right: -15px; margin-bottom: -15px; }

原理:這會在margin的水平和垂直方向上添加一個負值,IE添加了該精確數(shù)值后,便會去除對滾動條的需求假象。

優(yōu)點:在視覺上解決了這個問題,垂直滾動根據(jù)內容自適應。

缺點:由于“人為創(chuàng)建”了15px的外邊距(margin),所以無法使用該填充過的屏幕區(qū)域。

<body scroll=no>

去掉水平滾動條:

<body style="overflow-x: hidden">

去掉豎直滾動條:

<body style="overflow-y: hidden">

隱藏橫向滾動條,顯示縱向滾動條:

<body style="overflow-x:hidden;overflow-y:scroll">

全部隱藏

<body style="overflow:hidden">

或者是

<body scroll="no">

這里先說一下滾動條的屬性代碼:

overflow-y : visible | auto | hidden | scroll

visible :  不剪切內容也不添加滾動條。

auto :  在需要時剪切內容并添加滾動條

hidden :  不顯示超過對象高度的內容,這里不對這個屬性作介紹,大家喜歡的話可以自己嘗試

scroll :  總是顯示縱向滾動條

首先我現(xiàn)說一下去掉滾動條的方法:

如果用百度風格模版的話,滾動條只可能有一個,那就是整個空間右邊最大的瀏覽器窗口滾動條,也就是我美化過的那個滾動條,現(xiàn)在告訴大家,我們可以把這個滾動條去掉,但是卻不影響瀏覽的方法:

在body

{}中加入overflow-y :

visible就可以了,這樣滾動條就不會顯示出來了。大家可能會問,這樣怎么往下拉?呵呵,既然我說了不影響瀏覽,那當然是有方法的,瀏覽的方法就是用

鼠標的滾輪,雖然滾動條沒了,可是鼠標滾輪還是能夠讓網(wǎng)頁上下滾動的。我相信大家一般瀏覽網(wǎng)頁的時候用滾輪下拉網(wǎng)頁的次數(shù)應該比直接用鼠標拖動滾動條的次

數(shù)多吧?提示下,如果碰到?jīng)]有滾動條而鼠標又沒有滾輪的朋友,該怎么瀏覽網(wǎng)頁呢?呵呵,大家可以用鍵盤上面的方向鍵上方的PageUp和PageDown

來上下翻頁,也可以用空格往下拉網(wǎng)頁和Shift+空格往上拉網(wǎng)頁,還有一個方法就是用上下方向鍵來拉動,另外還有按Home鍵回到網(wǎng)頁頂部,End鍵到

達網(wǎng)頁底部,呵呵,是不是方法很多呢?不過這樣總會有那么一些些的不方便,所以大家可以根據(jù)自己的空間和喜好來考慮要不要取消這個滾動條。

哈哈,想不到啰哩叭嗦地,一下說了這么多話

下面我們說添加滾動條的方法:

overflow-y : auto;height:多少px

auto

就是自動判斷要不要加入滾動條,當設定的對象內容超過了height設定的高度時,就自動添加滾動條,不然則不顯示,body{}中的默認值就是

overflow-y : auto;height:瀏覽器高度,所以當網(wǎng)頁內容超過瀏覽器高度的時候,瀏覽器右邊就會自動顯現(xiàn)出滾動條來

大家如

果需要設置這個的話,本人建議設置在最新評論#m_comment{}、文章列表#m_blog{}等內容和高度都不固定的模版中,有的朋友找不到這些模

版的ID,可能只有例如#m_comment div.item{}或者#m_pro a{}等的ID,那么可以自己加上沒有的ID,這樣就可以設置了

這里還有另一個添加滾動條的方法:

overflow-y :scroll

這個參數(shù)的作用上面解釋過了,不過如果只加這個參數(shù)的話,雖然滾動欄會顯示,但是不會顯示滾動條,所以必須還要加上一個

height:多少px

高度屬性,跟上面的那個方法差不多,但是有根本的區(qū)別,這個無論對象內容的高度是否超過了height設定的高度,滾動欄永遠都會顯示在邊上的

下面我們說一下關于滾動條的美化,這個我朋友給我看了網(wǎng)上的一個說明,我覺得上面的圖很不錯,但是很小,所以我放大了一倍,看起來就清楚多了,我們先說一下美化的各個屬性:

代碼如下:

SCROLLBAR-FACE-COLOR: 顏色代碼;

SCROLLBAR-HIGHLIGHT-COLOR:顏色代碼;

SCROLLBAR-SHADOW-COLOR: 顏色代碼;

SCROLLBAR-3DLIGHT-COLOR: 顏色代碼;

SCROLLBAR-ARROW-COLOR: 顏色代碼;

SCROLLBAR-TRACK-COLOR: 顏色代碼;

SCROLLBAR-DARKSHADOW-COLOR: 顏色代碼;

大家是不是看到這么多屬性有點點頭大了?哈哈,放心,看一下我剛才提及的被我放大了一倍的圖解你們就會感覺好多了:

這里的圖片上還有一個scrollbar-base-color的屬性,其實這個屬性是個上面7個屬性的總合,怎么說呢?就是當你設定了這個屬性的顏色后,

前面的7個屬性都可以不用設置了,滾動條會自動幫你設定的,只是這個設定都會基于你設定的scrollbar-base-color的顏色而自動設定

這個屬性的優(yōu)點就是不用大家費盡心思的去研究各個地方的顏色,但是缺點就是不能夠融和五顏六色于一體。。

注:設定了scrollbar-base-color就不要設定其他七個屬性了,設定了其他七個屬性就不要設定scrollbar-base-color,不然之間可能會有沖突,會有一些效果不起作用的

最后,還是考慮到大家可能會喜歡我的美化代碼[真臭美~],我把我的美化代碼貼出來:

代碼如下:

SCROLLBAR-FACE-COLOR: #CCFFFF;

SCROLLBAR-HIGHLIGHT-COLOR: white;

SCROLLBAR-SHADOW-COLOR: #813533;

SCROLLBAR-3DLIGHT-COLOR: #813533;

SCROLLBAR-ARROW-COLOR: #813533;

SCROLLBAR-TRACK-COLOR: white;

SCROLLBAR-DARKSHADOW-COLOR: #813533;

以上代碼本人是加在body{}中的

更多信息請查看網(wǎng)頁制作
易賢網(wǎng)手機網(wǎng)站地址:關于HTML中的滾動條/去掉滾動條問題
由于各方面情況的不斷調整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢?yōu)闇剩?/div>

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權所有:易賢網(wǎng)