主頁 > 知識庫 > 關(guān)于HTML中的滾動條/去掉滾動條問題

關(guān)于HTML中的滾動條/去掉滾動條問題

熱門標(biāo)簽:阿里云 美圖手機(jī) 智能手機(jī) 檢查注冊表項(xiàng) 百度競價點(diǎn)擊價格的計(jì)算公式 使用U盤裝系統(tǒng) 硅谷的囚徒呼叫中心 網(wǎng)站建設(shè)
1.xhtml下滾動條的顏色問題

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

復(fù)制代碼
代碼如下:

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:#;/*- 滑道 -*/
}

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

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

復(fù)制代碼
代碼如下:

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)依然可以實(shí)現(xiàn)效果。那到底是為什么呢?

我們來看一下下面的圖:

這就是html最基本的dom樹結(jié)構(gòu)。

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

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

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

從字面上來看,xhtml比html多一個x,那么這個x其實(shí)也就是xml,為什么要加一個xml在里面?其實(shí)最根本的原因就是要讓html更加結(jié)構(gòu)化標(biāo)準(zhǔn)化(因?yàn)閔tml實(shí)在是太爛)。

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

復(fù)制代碼
代碼如下:

*{
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都通過,因?yàn)?就是定義頁面上的任何標(biāo)簽當(dāng)然也包括了“html”這個標(biāo)簽。

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

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

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

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

方法1:

代碼:

html { overflow-y: scroll; }

原理:強(qiáng)制顯示ie的垂直滾動條,而忽略水平滾動條。
優(yōu)點(diǎn):完全解決了這個問題, 允許你保持完整的XHTML doctype 。
缺點(diǎn):即使頁面不需要垂直滾動條的時候也會出現(xiàn)垂直滾動條。

方法2:

代碼:

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

原理:隱藏橫向滾動,垂直滾動根據(jù)內(nèi)容自適應(yīng)。
優(yōu)點(diǎn):在視覺上解決了這個問題。在不必要的時候,未強(qiáng)制垂直滾動條出現(xiàn)。
缺點(diǎn):只是隱藏了水平滾動條,如果頁面真正需要水平滾動條的時候,屏幕以外的內(nèi)容會因?yàn)橛脩魺o法水平滾動,而看不到。

方法3:

代碼:

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

原理:這會在margin的水平和垂直方向上添加一個負(fù)值,IE添加了該精確數(shù)值后,便會去除對滾動條的需求假象。
優(yōu)點(diǎn):在視覺上解決了這個問題,垂直滾動根據(jù)內(nèi)容自適應(yīng)。
缺點(diǎn):由于“人為創(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 :  不剪切內(nèi)容也不添加滾動條。
auto :  在需要時剪切內(nèi)容并添加滾動條
hidden :  不顯示超過對象高度的內(nèi)容,這里不對這個屬性作介紹,大家喜歡的話可以自己嘗試
scroll :  總是顯示縱向滾動條

首先我現(xiàn)說一下去掉滾動條的方法:
如果用百度風(fēng)格模版的話,滾動條只可能有一個,那就是整個空間右邊最大的瀏覽器窗口滾動條,也就是我美化過的那個滾動條,現(xiàn)在告訴大家,我們可以把這個滾動條去掉,但是卻不影響瀏覽的方法:
在body
{}中加入overflow-y :
visible就可以了,這樣滾動條就不會顯示出來了。大家可能會問,這樣怎么往下拉?呵呵,既然我說了不影響瀏覽,那當(dāng)然是有方法的,瀏覽的方法就是用
鼠標(biāo)的滾輪,雖然滾動條沒了,可是鼠標(biāo)滾輪還是能夠讓網(wǎng)頁上下滾動的。我相信大家一般瀏覽網(wǎng)頁的時候用滾輪下拉網(wǎng)頁的次數(shù)應(yīng)該比直接用鼠標(biāo)拖動滾動條的次
數(shù)多吧?提示下,如果碰到?jīng)]有滾動條而鼠標(biāo)又沒有滾輪的朋友,該怎么瀏覽網(wǎng)頁呢?呵呵,大家可以用鍵盤上面的方向鍵上方的PageUp和PageDown
來上下翻頁,也可以用空格往下拉網(wǎng)頁和Shift+空格往上拉網(wǎng)頁,還有一個方法就是用上下方向鍵來拉動,另外還有按Home鍵回到網(wǎng)頁頂部,End鍵到
達(dá)網(wǎng)頁底部,呵呵,是不是方法很多呢?不過這樣總會有那么一些些的不方便,所以大家可以根據(jù)自己的空間和喜好來考慮要不要取消這個滾動條。

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

下面我們說添加滾動條的方法:
overflow-y : auto;height:多少px
auto
就是自動判斷要不要加入滾動條,當(dāng)設(shè)定的對象內(nèi)容超過了height設(shè)定的高度時,就自動添加滾動條,不然則不顯示,body{}中的默認(rèn)值就是
overflow-y : auto;height:瀏覽器高度,所以當(dāng)網(wǎng)頁內(nèi)容超過瀏覽器高度的時候,瀏覽器右邊就會自動顯現(xiàn)出滾動條來
大家如
果需要設(shè)置這個的話,本人建議設(shè)置在最新評論#m_comment{}、文章列表#m_blog{}等內(nèi)容和高度都不固定的模版中,有的朋友找不到這些模
版的ID,可能只有例如#m_comment div.item{}或者#m_pro a{}等的ID,那么可以自己加上沒有的ID,這樣就可以設(shè)置了

這里還有另一個添加滾動條的方法:
overflow-y :scroll
這個參數(shù)的作用上面解釋過了,不過如果只加這個參數(shù)的話,雖然滾動欄會顯示,但是不會顯示滾動條,所以必須還要加上一個
height:多少px
高度屬性,跟上面的那個方法差不多,但是有根本的區(qū)別,這個無論對象內(nèi)容的高度是否超過了height設(shè)定的高度,滾動欄永遠(yuǎn)都會顯示在邊上的

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

復(fù)制代碼
代碼如下:

SCROLLBAR-FACE-COLOR: 顏色代碼;
SCROLLBAR-HIGHLIGHT-COLOR:顏色代碼;
SCROLLBAR-SHADOW-COLOR: 顏色代碼;
SCROLLBAR-3DLIGHT-COLOR: 顏色代碼;
SCROLLBAR-ARROW-COLOR: 顏色代碼;
SCROLLBAR-TRACK-COLOR: 顏色代碼;
SCROLLBAR-DARKSHADOW-COLOR: 顏色代碼;

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

這里的圖片上還有一個scrollbar-base-color的屬性,其實(shí)這個屬性是個上面7個屬性的總合,怎么說呢?就是當(dāng)你設(shè)定了這個屬性的顏色后,
前面的7個屬性都可以不用設(shè)置了,滾動條會自動幫你設(shè)定的,只是這個設(shè)定都會基于你設(shè)定的scrollbar-base-color的顏色而自動設(shè)定
這個屬性的優(yōu)點(diǎn)就是不用大家費(fèi)盡心思的去研究各個地方的顏色,但是缺點(diǎn)就是不能夠融和五顏六色于一體。。

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

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

復(fù)制代碼
代碼如下:

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{}中的

標(biāo)簽:懷化 通遼 黃山 湖北 山南 煙臺 湘潭 賀州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《關(guān)于HTML中的滾動條/去掉滾動條問題》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266