首頁 > web前端 > 前端問答 > css3中vh和wh是什麼單位

css3中vh和wh是什麼單位

青灯夜游
發布: 2022-02-28 16:21:41
原創
10073 人瀏覽過

在css3中,vh和wh是視口單位,是相對長度單位。 wh是相對於視口的寬度,「1vw」等於視口寬度的「1%」;而vh是相對於視口的高度,「1vh」等於視口高度的「1%」。

css3中vh和wh是什麼單位

本教學操作環境:windows7系統、CSS3&&HTML5版、Dell G3電腦。

在css3中,vh和wh是視口單位,是相對長度單位。

視窗單位( Viewport units )

首先,我們要了解什麼是視口。在業界,極為推崇的一種理論是Peter-Paul Koch (江湖人稱「PPK大神」)提出的關於視口的解釋-在桌面端,視口指的是在桌面端,指的是瀏覽器的視覺區域;而在行動端較為複雜,它涉及三個視窗:分別是Layout Viewport(佈局視窗)、 Visual Viewport(視覺視窗)、Ideal Viewport。而視口單位中的“視口”,在桌面端,毫無疑問指的就是瀏覽器的可視區域;但是在行動端,它指的則是三個 Viewport 中的 Layout Viewport 。

css3中vh和wh是什麼單位

視窗單位中的「視口」 根據CSS3規範,視口單位主要包括以下4個:

  • ##vw : 相對於視窗的寬度,1vw 等於視窗寬度的1%

  • vh : 相對於視窗的高度, 1vh 等於視窗高度的1%

  • vmin : 選取vw 和vh 中最小的那個

  • #vmax : 選取vw 和vh 中最大的那個

#視口單位區別於%單位,視口單位是依賴視口的尺寸,根據視口尺寸的百分比來定義的;而%單位則是依賴於元素的祖先元素。

css3中vh和wh是什麼單位

以視窗單位測量,視窗寬度為100vw,高度為100vh(左側為垂直螢幕情況,右側為橫向螢幕情況) 例如,在桌面端瀏覽器視窗尺寸為650px,那麼1vw = 650 * 1% = 6.5px(這是理論推算的出,如果瀏覽器不支援0.5px,那麼實際渲染結果可能是7px)。

利用視窗單位適配頁面

#對於行動裝置開發來說,最為重要的一點是如何適應頁面,實作多終端的兼容,不同的適配方式各有千秋,也各有缺點。就主流的響應式佈局、彈性佈局來說,透過Media Queries 實現的佈局需要配置多個響應斷點,而且帶來的體驗也對用戶十分的不友好:佈局在響應斷點範圍內的分辨率下維持不變,而在響應斷點切換的瞬間,佈局帶來斷層式的切換變化,如同卡帶的唱機般“咔咔咔”地一下又一下。而透過採用rem單位的動態計算的彈性佈局,則是需要在頭部內嵌一段腳本來進行監聽分辨率的變化來動態改變根元素字體大小,使得 CSS 與 JS 耦合了在一起。有沒有辦法能夠解決這樣的問題呢?答案是肯定的,透過利用視口單位實現適配的頁面,是既能解決響應式斷層問題,又能解決腳本依賴的問題的。

做法一:僅使用vw作為CSS單位

在僅使用vw 單位作為唯一應用的一種CSS 單位的這種做法下,我們遵守: 1 .對於設計稿的尺寸轉換為vw單位,我們使用Sass函數編譯

//iPhone 6尺寸作为设计稿基准
$vm_base: 375; 
@function vw($px) {
    @return ($px / 375) * 100vw;
}
登入後複製

2.無論是文字或佈局高寬、間距等都使用vw 作為CSS 單位

.mod_nav {
    background-color: #fff;
    &_list {
        display: flex;
        padding: vm(15) vm(10) vm(10); // 内间距
        &_item {
            flex: 1;
            text-align: center;
            font-size: vm(10); // 字体大小
            &_logo {
                display: block;
                margin: 0 auto;
                width: vm(40); // 宽度
                height: vm(40); // 高度
                img {
                    display: block;
                    margin: 0 auto;
                    max-width: 100%;
                }
            }
            &_name {
                margin-top: vm(2);
            }
        }
    }
}
登入後複製

3.1物理像素線(也就是普通螢幕下1px ,高清螢幕下0.5px 的情況)採用transform 屬性scale 實作。

.mod_grid {
    position: relative;
    &::after {
        // 实现1物理像素的下边框线
        content: '';
        position: absolute;
        z-index: 1;
        pointer-events: none;
        background-color: #ddd;
        height: 1px;
        left: 0;
        right: 0;
        top: 0;
        @media only screen and (-webkit-min-device-pixel-ratio: 2) {
            -webkit-transform: scaleY(0.5);
            -webkit-transform-origin: 50% 0%;
        }
    }
    ...
}
登入後複製

4.對於需要保持高寬比的圖,應改用padding-top 實作

.mod_banner {
    position: relative;
    padding-top: percentage(100/700); // 使用padding-top
    height: 0;
    overflow: hidden;
    img {
        width: 100%;
        height: auto;
        position: absolute;
        left: 0;
        top: 0; 
    }
}
登入後複製

由此,我們能夠實現一個常見佈局的頁面效果如下:

做法二:搭配vw和rem,佈局更優化

這樣的頁面雖然看起來適配得很好,但是你會發現由於它是利用視口單位實現的佈局,依賴視口大小而自動縮放,無論視口過大或過小,它也隨著視口過大或過小,失去了最大最小寬度的限制。當然,你可以不在乎這樣微小的不友善使用者體驗,但我們還是嘗試下追求修復這樣的小瑕疵吧。於是,聯想到不如結合rem單位來實現佈局? rem 彈性佈局的核心在於動態改變根元素大小,那麼我們可以透過:

給根元素大小設定隨著視窗變化而變化的 vw 單位,這樣就可以實現動態改變其大小。

限制根元素字體大小的最大最小值,配合 body 加上最大寬度和最小寬度

這樣我們就能夠實現對佈局寬度的最大最小限制。因此,根據以上條件,我們可以得出程式碼實作如下:

// rem 单位换算:定为 75px 只是方便运算,750px-75px、640-64px、1080px-108px,如此类推
$vm_fontsize: 75; // iPhone 6尺寸的根元素大小基准值
@function rem($px) {
     @return ($px / $vm_fontsize ) * 1rem;
}
// 根元素大小使用 vw 单位
$vm_design: 750;
html {
    font-size: ($vm_fontsize / ($vm_design / 2)) * 100vw; 
    // 同时,通过Media Queries 限制根元素最大最小值
    @media screen and (max-width: 320px) {
        font-size: 64px;
    }
    @media screen and (min-width: 540px) {
        font-size: 108px;
    }
}
// body 也增加最大最小宽度限制,避免默认100%宽度的 block 元素跟随 body 而过大过小
body {
    max-width: 540px;
    min-width: 320px;
}
登入後複製

(学习视频分享:css视频教程web前端入门教程

以上是css3中vh和wh是什麼單位的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板