中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

如何使用css的overflow屬性定義滾動條

本篇文章給大家分享的是有關(guān)如何使用css的overflow屬性定義滾動條,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

創(chuàng)新互聯(lián)于2013年創(chuàng)立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢想脫穎而出為使命,1280元棗陽做網(wǎng)站,已為上家服務(wù),為棗陽各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18982081108

滾動條在網(wǎng)頁中經(jīng)常見到,卻并沒有受到足夠的重視。只有當(dāng)因?yàn)闈L動條的問題需要處理兼容性時(shí),才進(jìn)行調(diào)試操作。本章就給大家?guī)韈ss滾動條的常見內(nèi)容。

一:條件
     滾動條和overflow是緊密相關(guān)的。只有當(dāng)父級的overflow的值是auto或scroll,并且元素的內(nèi)容超出元素區(qū)域時(shí),才有可能出現(xiàn)滾動條

如何使用css的overflow屬性定義滾動條

二:默認(rèn)

無論什么瀏覽器,默認(rèn)滾動條均來自<html>,而不是<body>。因?yàn)?lt;body>元素默認(rèn)有8px的margin。若滾動條來自<body>元素,則滾動條與頁面則應(yīng)該有8px的間距,實(shí)際上并沒有間距,所以滾動條來自<html>元素

三:尺寸

通過以下代碼可得出滾動條會占用瀏覽器的可用寬度為:

chrome/firefox/IE 17px
safari 21px
.box{
    width: 400px;
    overflow: scroll;
}
.in{
    *zoom: 1;
}
<div class="box">
    <div id="in" class="in"></div>
</div>
console.log(400-document.getElementById('in').clientWidth);

兼容

【1】默認(rèn)情況下IE7-瀏覽器默認(rèn)有一條縱向滾動條,而其他瀏覽器則沒有

//IE7-瀏覽器 
html{overflow-y: scroll;}
//其他瀏覽器
html{overflow: auto;}
//去除頁面默認(rèn)滾動條
html{overflow: hidden;}

【2】IE7-瀏覽器與其他瀏覽器關(guān)于滾動條的寬度設(shè)定機(jī)制不同

.box{
    width: 200px;
    height: 100px;
    background-color: pink;
    overflow: scroll;
}
.in{
    width: 100%;
    height: 60px;
    background-color: lightgreen;
}
<div class="box">
    <div class="in">測試文字</div>
 </div>

父級box出現(xiàn)縱向滾動條,實(shí)際上子級in的可用寬度就縮小了。IE7-瀏覽器的子級寬度忽略了該滾動條的寬度,子級寬度=400*100%=400px,則出現(xiàn)了橫向滾動條;而其他瀏覽器的子級寬度考慮到該滾動條的寬度,子級寬度=(400-滾動條寬度)*100%

左邊為IE7-瀏覽器,右邊為其他瀏覽器

如何使用css的overflow屬性定義滾動條

【3】水平居中跳動問題

當(dāng)一個(gè)元素在頁面中水平居中時(shí),頁面中出現(xiàn)縱向滾動條會發(fā)生水平居中的跳出問題。解決方法如下:

//IE8-默認(rèn)
html{overflow-y: scroll}//IE9+,100vw表示瀏覽器的寬度,100%表示可用內(nèi)容的寬度
.container{padding-left: calc(100vw-100%)}

自定義

【1】IE

IE瀏覽器支持通過CSS樣式來改變滾動條的部件的自定義顏色

scrollbar-face-color 滾動條凸出部分的顏色
scrollbar-shadow-color 立體滾動條陰影的顏色
scrollbar-highlight-color 滾動條空白部分的顏色
scrollbar-3dlight-color 滾動條亮邊的顏色
scrollbar-darkshadow-color 滾動條強(qiáng)陰影的顏色
scrollbar-track-color 滾動條的背景顏色 
scrollbar-arrow-color 上下按鈕上三角箭頭的顏色 
scrollbar-base-color  滾動條的基本顏色

如何使用css的overflow屬性定義滾動條

【2】webkit

webkit內(nèi)核的瀏覽器支持滾動條自定義樣式,但和IE不同,webkit是通過偽類來實(shí)現(xiàn)的組成

::-webkit-scrollbar 滾動條整體部分
::-webkit-scrollbar-thumb 滾動滑塊
::-webkit-scrollbar-track 外層軌道
::-webkit-scrollbar-track-piece 內(nèi)層軌道
::-webkit-scrollbar-corner 邊角
::-webkit-scrollbar-button 兩端按鈕

[注意]當(dāng)為滾動條設(shè)置寬高樣式為百分比值時(shí),是相對視窗大小來說的

如何使用css的overflow屬性定義滾動條

[注意]滾動條的層疊關(guān)系為scrollbar在最底層,往上依次是track外層軌道,track-piece內(nèi)層軌道。而button按鈕、corner邊角和thumb滑塊有最頂層

四:偽類相關(guān)

:horizontal
//horizontal偽類適用于任何水平方向上的滾動條

:vertical
//vertical偽類適用于任何垂直方向的滾動條

:decrement
//decrement偽類適用于按鈕和軌道碎片。表示遞減的按鈕或軌道碎片,例如可以使區(qū)域向上或者向右移動的區(qū)域和按鈕

:increment
//increment偽類適用于按鈕和軌道碎片。表示遞增的按鈕或軌道碎片,例如可以使區(qū)域向下或者向左移動的區(qū)域和按鈕

:start
//start偽類適用于按鈕和軌道碎片。表示對象(按鈕 軌道碎片)是否放在滑塊的前面

:end
//end偽類適用于按鈕和軌道碎片。表示對象(按鈕 軌道碎片)是否放在滑塊的后面

:double-button
//double-button偽類適用于按鈕和軌道碎片。判斷軌道結(jié)束的位置是否是一對按鈕。也就是軌道碎片緊挨著一對在一起的按鈕。

:single-button
//single-button偽類適用于按鈕和軌道碎片。判斷軌道結(jié)束的位置是否是一個(gè)按鈕。也就是軌道碎片緊挨著一個(gè)單獨(dú)的按鈕。

:no-button
no-button偽類表示軌道結(jié)束的位置沒有按鈕。

:corner-present
//corner-present偽類表示滾動條的角落是否存在。

:window-inactive
//適用于所有滾動條,表示包含滾動條的區(qū)域,焦點(diǎn)不在該窗口的時(shí)候。

::-webkit-scrollbar-track-piece:start {
/*滾動條上半邊或左半邊*/
}

::-webkit-scrollbar-thumb:window-inactive {
/*當(dāng)焦點(diǎn)不在當(dāng)前區(qū)域滑塊的狀態(tài)*/
}

::-webkit-scrollbar-button:horizontal:decrement:hover {
/*當(dāng)鼠標(biāo)在水平滾動條下面的按鈕上的狀態(tài)*/
}

以上就是如何使用css的overflow屬性定義滾動條,小編相信有部分知識點(diǎn)可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

文章題目:如何使用css的overflow屬性定義滾動條
分享地址:http://www.rwnh.cn/article4/jdghie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、Google、ChatGPT、全網(wǎng)營銷推廣、小程序開發(fā)微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營
藁城市| 临夏县| 哈尔滨市| 石嘴山市| 清远市| 应用必备| 宁津县| 昆明市| 石嘴山市| 黑河市| 佛学| 大名县| 眉山市| 通渭县| 安泽县| 高雄市| 荆门市| 新野县| 皋兰县| 桑植县| 安新县| 西畴县| 平昌县| 大邑县| 瑞丽市| 邢台市| 榆中县| 长宁区| 松原市| 西城区| 合作市| 祁门县| 兴化市| 霸州市| 三原县| 普安县| 鲁山县| 灵川县| 濉溪县| 密山市| 健康|