您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“CSS3滾動條出現(xiàn)頁面不跳動如何解決”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“CSS3滾動條出現(xiàn)頁面不跳動如何解決”吧!
什么是calc()?
calc()從字面我們可以把他理解為一個函數(shù)function。其實calc是英文單詞calculate(計算)的縮寫,是css3的一個新增的功能,用來指定元素的長度。比如說,你可以使用calc()給元素的border、margin、pading、font-size和width等屬性設(shè)置動態(tài)值。為何說是動態(tài)值呢?因為我們使用的表達(dá)式來得到的值。不過calc()最大的好處就是用在流體布局上,可以通過calc()計算得到元素的寬度。
語法
calc() = calc(四則運(yùn)算)
例如:
.elm { width: calc(expression); }
其中"expression"是一個表達(dá)式,用來計算長度的表達(dá)式
說明
用于動態(tài)計算長度值。
需要注意的是,運(yùn)算符前后都需要保留一個空格,例如:width: calc(100% - 10px);
任何長度值都可以使用calc()函數(shù)進(jìn)行計算;
calc()函數(shù)支持 "+", "-", "*", "/" 運(yùn)算;
calc()函數(shù)使用標(biāo)準(zhǔn)的數(shù)學(xué)運(yùn)算優(yōu)先級規(guī)則;
簡單的例子:
<!DOCTYPE html> <html lang="zh-cmn-Hans"> <head> <meta charset="utf-8" /> <title>calc()函數(shù)_CSS參考手冊_web前端開發(fā)參考手冊系列</title> <meta name="author" content="Joy Du(飄零霧雨), dooyoe@gmail.com, www.doyoe.com" /> <style> .test { width: calc(100% - 50px); background: #eee; } </style> </head> <body> <div class="test">我的寬度為100% - 50px</div> </body> </html>
下面就來講解下最常用的這個:實現(xiàn)滾動條出現(xiàn)頁面不跳動的應(yīng)用
當(dāng)頁面內(nèi)容動態(tài)加載,開始沒有滾動條,內(nèi)容增多后出現(xiàn)滾動條,這時使用固定寬度居中對齊布局會向左偏移一個滾動條寬度。解決方法可以給內(nèi)容全部添加overflow-y:scroll;或者是根據(jù)內(nèi)容用css填充好再補(bǔ)充內(nèi)容。本文介紹的是calc來計算滾動條寬度,當(dāng)有滾動條時,內(nèi)容外部也給它模擬一個滾動條寬度,因而就不會偏移了。·
很簡單,只要一行代碼就搞定了:
.wrap-outer { margin-left: calc(100vw - 100%); }
或者:
.wrap-outer { padding-left: calc(100vw - 100%); }
首先,.wrap-outer指的是居中定寬主體的父級,如果沒有,創(chuàng)建一個(使用主體也是可以實現(xiàn)類似效果,不過本著寬度分離原則,不推薦);
然后,calc是css3中的計算,IE10+瀏覽器支持,IE9瀏覽器基本支持(不能用在background-position上);
最后,100vw相對于瀏覽器的window.innerWidth,是瀏覽器的內(nèi)部寬度,注意,滾動條寬度也計算在內(nèi)!而100%是可用寬度,是不含滾動條的寬度。
于是,calc(100vw - 100%)就是瀏覽器滾動條的寬度大小(如果有,如果沒有滾動條則是0)!左右都有一個滾動條寬度(或都是0)被占用,主體內(nèi)容就可以永遠(yuǎn)居中瀏覽器啦,從而沒有任何跳動!
到此,相信大家對“CSS3滾動條出現(xiàn)頁面不跳動如何解決”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。
億速云公眾號
手機(jī)網(wǎng)站二維碼
Copyright ? Yisu Cloud Ltd. All Rights Reserved. 2018 版權(quán)所有
廣州億速云計算有限公司粵ICP備17096448號-1 粵公網(wǎng)安備 44010402001142號增值電信業(yè)務(wù)經(jīng)營許可證編號:B1-20181529