因為最近公司做的項目需要用到捲軸(項目在webkit平台下運行),所以研究下捲軸的CSS。
瀏覽器預設的捲軸樣子太過屌絲了,得自己動手整整。記得IE瀏覽器有幾個設定滾條的樣式,不過比較雞肋,只能設定顏色之類的,而且webkit下面也不支援。無意間看到網易郵箱的捲軸樣子很好看,一開始以為是用div類比的,結果一看,吼吼,正合我意,利用的CSS來設定的,而且是webkit瀏覽器的。
得好好研究這幾個屬性下,才能自己動手改造。
webkit瀏覽器css設定捲軸
主要有下面7個屬性
::-webkit-scrollbar 捲軸整體部分,可以設定寬度啥的
::-webkit-scrollbar-button 捲軸兩端的按鈕
::-webkit-scrollbar-track 外層軌道
::-webkit-scrollbar-track-piece 內層滾動槽
::-webkit-scrollbar-thumb 滾動的滑塊
::-webkit-scrollbar-corner 邊角
::-webkit-resizer 定義右下角拖動塊的樣式
具體所指例
上面是捲軸的主要幾個設定屬性,還有更詳盡的CSS屬性
:horizontal 水平方向的捲軸
:vertical 垂直 方向的捲軸
:decrement 應用於按鈕和內層軌道(track piece)。它用來指示按鈕或者內層軌道是否會減小視窗的位置(比如,垂直捲軸的上面,水平捲軸的左邊。)
:increment decrement類似,用來指示按鈕或內層軌道是否會增大視窗的位置(比如,垂直捲軸的下面和水平捲軸的右邊。)
:start 偽類也應用於按鈕和滑塊。它用來定義對象是否放到滑塊的前面。
:end 類似於start偽類,標識對象是否放到滑塊的後面。
:double-button 該偽類以用於按鈕和內層軌道。用於判斷一個按鈕是不是放在捲軸同一端的一對按鈕中的一個。對於內層軌道來說,它表示內層軌道是否緊靠一對按鈕。
:single-button 類似於double-button偽類。對按鈕來說,它用於判斷一個按鈕是否自己獨立的在捲軸的一段。對內層軌道來說,它表示內層軌道是否緊靠一個single-button。
:no-button 用於內層軌道,表示內層軌道是否要滾動到捲軸的終端,比如,捲軸兩端沒有按鈕的時候。
:corner-present 用於所有捲軸軌道,指示捲軸圓角是否顯示。
:window-inactive 用於所有的捲軸軌道,指示應用捲軸的某個頁面容器(元素)是否當前被啟用。(在webkit最近的版本中,該偽類也可以用於::selection虛擬元素。webkit團隊有計劃擴充它並推動成為一個標準的偽類)
寫個執行個體demo吧(請在webkit瀏覽器下觀看),不能光說不練。CSS也很簡單。
/* 設定捲軸的樣式 */::-webkit-scrollbar {width: 12px;}/* 滾動槽 */::-webkit-scrollbar-track {-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3);border-radius: 10px;}/* 捲軸滑塊 */::-webkit-scrollbar-thumb {border-radius: 10px;background: rgba(0,0,0,0.1);-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.5);}::-webkit-scrollbar-thumb:window-inactive {background: rgba(255,0,0,0.4);}
IE下面的CSS設定捲軸
IE下面就比較簡單那了,自訂的項目比較少,全是顏色。
scrollbar-arrow-color: color; /*三角箭頭的顏色*/
scrollbar-face-color: color; /*立體捲軸的顏色(包括箭頭部分的背景色)*/
scrollbar-3dlight-color: color; /*立體捲軸亮邊的顏色*/
scrollbar-highlight-color: color; /*捲軸的醒目提示(左陰影?)*/
scrollbar-shadow-color: color; /*立體捲軸陰影的顏色*/
scrollbar-darkshadow-color: color; /*立體捲軸外陰影的顏色*/
scrollbar-track-color: color; /*立體捲軸背景顏色*/
scrollbar-base-color:color; /*捲軸的基色*/