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”測試一下,發現依然可以實現效果。那到底是為什麼呢。
我們來看一下下面的圖:
這就是html最基本的dom樹結構。
我們再看看html和xhtml的定義:
HTML (Hyper Text Markup Language,超檔案標記語言),超檔案標記語言廣泛應用於國際互連網上.HTML描述了文本基準如何進行呈現,以及超級串連如何串連到另外的頁面。
XHTML (Extensible Hypertext Markup Language,可擴充的超檔案標記語言),是一種標記語言,表現方式與 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才是根項目,而頁面的捲軸也是屬於根項目的,所以這就是我們為什麼定義body沒有效果的原因,因為我們定義的只是一個子原素。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的區別到不如說是有無XHTML 1.0 transitional doctype的區別,但是如果你把頁面的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頁面的時候,預設會水平和垂直捲軸會一起出現,這是ie6的一個bug,在firefox上是正常的,出現的原因是其對XHTML 1.0 transitional doctype的解釋缺陷。
對於這個bug一般有3種解決方案,
方法1:
代碼:
html { overflow-y: scroll; }
原理:強制顯示ie的垂直捲軸,而忽略水平捲軸。
優點:完全解決了這個問題, 允許你保持完整的XHTML doctype 。
缺點:即使頁面不需要垂直捲軸的時候也會出現垂直捲軸。
方法2:
代碼:
html { overflow-x: hidden; overflow-y: auto; }
原理:隱藏橫向滾動,垂直滾動根據內容自適應。
優點:在視覺上解決了這個問題。在不必要的時候,未強制垂直捲軸出現。
缺點:只是隱藏了水平捲軸,如果頁面真正需要水平捲軸的時候,螢幕以外的內容會因為使用者無法水平滾動,而看不到。
方法3:
代碼:
body { margin-right: -15px; margin-bottom: -15px; }
原理:這會在margin的水平和垂直方向上添加一個負值,IE添加了該精確數值後,便會去除對捲軸的需求假象。
優點:在視覺上解決了這個問題,垂直滾動根據內容自適應。
缺點:由於“人為建立”了15px的外邊距(margin),所以無法使用該填充過的螢幕地區。
<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 : 總是顯示縱向捲軸
首先我現說一下去掉捲軸的方法:
如果用百度風格模版的話,捲軸只可能有一個,那就是整個空間右邊最大的瀏覽器視窗捲軸,也就是我美化過的那個捲軸,現在告訴大家,我們可以把這個捲軸去掉,但是卻不影響瀏覽的方法:
在body
{}中加入overflow-y :
visible就可以了,這樣捲軸就不會顯示出來了。大家可能會問,這樣怎麼往下拉。呵呵,既然我說了不影響瀏覽,那當然是有方法的,瀏覽的方法就是用
滑鼠的滾輪,雖然捲軸沒了,可是滑鼠滾輪還是能夠讓網頁上下滾動的。我相信大家一般瀏覽網頁的時候用滾輪下拉網頁的次數應該比直接用滑鼠拖動捲軸的次
數多吧。提示下,如果碰到沒有捲軸而滑鼠又沒有滾輪的朋友,該怎麼瀏覽網頁呢。呵呵,大家可以用鍵盤上面的方向鍵上方的PageUp和PageDown
來上下翻頁,也可以用空格往下拉網頁和Shift+空格往上拉網頁,還有一個方法就是用上下方向鍵來拉動,另外還有按Home鍵回到網頁頂部,End鍵到
達網頁底部,呵呵,是不是方法很多呢。不過這樣總會有那麼一些些的不方便,所以大家可以根據自己的空間和喜好來考慮要不要取消這個捲軸。
哈哈,想不到囉哩叭嗦地,一下說了這麼多話
下面我們說添加捲軸的方法:
overflow-y : auto;height:多少px
auto
就是自動判斷要不要加入捲軸,當設定的對象內容超過了height設定的高度時,就自動添加捲軸,不然則不顯示,body{}中的預設值就是
overflow-y : auto;height:瀏覽器高度,所以當網頁內容超過瀏覽器高度的時候,瀏覽器右邊就會自動顯現出捲軸來
大家如
果需要設定這個的話,本人建議設定在最新評論#m_comment{}、文章列表#m_blog{}等內容和高度都不固定的模版中,有的朋友找不到這些模
版的ID,可能只有例如#m_comment div.item{}或者#m_pro a{}等的ID,那麼可以自己加上沒有的ID,這樣就可以設定了
這裡還有另一個添加捲軸的方法:
overflow-y :scroll
這個參數的作用上面解釋過了,不過如果只加這個參數的話,雖然滾動欄會顯示,但是不會顯示捲軸,所以必須還要加上一個
height:多少px
高度屬性,跟上面的那個方法差不多,但是有根本的區別,這個無論對象內容的高度是否超過了height設定的高度,滾動欄永遠都會顯示在邊上的
下面我們說一下關於捲軸的美化,這個我朋友給我看了網上的一個說明,我覺得上面的圖很不錯,但是很小,所以我放大了一倍,看起來就清楚多了,我們先說一下美化的各個屬性:
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的顏色而自動設定
這個屬性的優點就是不用大家費盡心思的去研究各個地方的顏色,但是缺點就是不能夠融和五顏六色於一體。。
註:設定了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{}中的