主頁 > 知識庫 > 為什么你寫的height:100%不起作用

為什么你寫的height:100%不起作用

熱門標簽:中紳電銷智能機器人 鶴壁手機自動外呼系統(tǒng)怎么安裝 濟南辦理400電話 ai電銷機器人連接網(wǎng)關 威海營銷外呼系統(tǒng)招商 農(nóng)村住宅地圖標注 跟電銷機器人做同事 鄭州電銷外呼系統(tǒng)違法嗎 漳州人工外呼系統(tǒng)排名

為什么你寫的height:100%不起作用?

這個知識不算冷門的,但是用的時候可能還是會有些懵逼,不能生效時搜一搜就能找到答案了,但是你真的懂了嗎?為什么想要設置一個全屏元素的時候,高度不受%的控制?

1.百分比寬高的設定

按照w3c中的width和height屬性,可以明確%設定寬高是根據(jù)父元素的寬高來的:
https://www.w3school.com.cn/cssref/pr_dim_width.asp
https://www.w3school.com.cn/cssref/pr_dim_height.asp

2.width:100%;

我們寫下這樣一段代碼,隨意設置一個背景色便于觀察元素。注意以下代碼,記得加上<!DOCTYPE html>,否則會有所不同。

<body>
    <div style="width:100%;height:100%;background-color:blueviolet;">
    width:100%;height:100%;
    </div>
</body>
//寬100%,我們現(xiàn)在看到的高是屬于font-size的,而不是100%;

<body>
    <div style="width:100%;height:200px;background-color:blueviolet;">
    width:100%;height:200px;
    </div>
</body>
//效果如下

可以看到基本上寬的100%很容易就實現(xiàn)的,但是這里的height卻不能設置成%比的(該元素會消失看不見),這是為什么呢?

3.瀏覽器是如何計算高度和寬度的

Web瀏覽器在計算有效寬度時會考慮瀏覽器窗口的打開寬度。如果你不給寬度設定任何缺省值,那瀏覽器會自動將頁面內容平鋪填滿整個橫向寬度。即我們不設置寬,會自動填滿整個橫向寬度,如下:

<div style="height:100%;">height:100%;</div>

但是高度的計算方式完全不一樣。事實上,瀏覽器根本就不計算內容的高度,除非內容超出了視窗范圍(導致滾動條出現(xiàn))?;蛘吣憬o整個頁面設置一個絕對高度。否則,瀏覽器就會簡單的讓內容往下堆砌,頁面的高度根本就無需考慮。
因為頁面并沒有缺省的高度值,所以,當你讓一個元素的高度設定為百分比高度時,無法根據(jù)獲取父元素的高度,也就無法計算自己的高度。
即父元素的高度只是一個缺省值:height: auto;我們設置height:100%時,是要求瀏覽器根據(jù)這樣一個缺省值來計算百分比高度時,只能得到undefined的結果。也就是一個null值,瀏覽器不會對這個值有任何的反應。
各個瀏覽器對于寬高的解析也不相同,大家可以自己搜索一下。
 

4.如何解決

現(xiàn)在你知道了吧,%是一個相對父元素計算得來的高度,要想使他有效,我們需要設置父元素的height;
要特別注意的一點是,在<body>之中的元素的父元素并不僅僅只是<body>,還包括了<html>。
所以我們要同時設置這兩者的height,只設置其中一個是不行的:

 html,body{
            height: 100%;
            margin: 0;
            padding: 0;
        }

5.關于line-height居中的一點誤解?

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        html,body{
            height: 100%;
            margin: 0;
            padding: 0;
        }
        div {
            color: white;
            text-align: center;
            font-size: 30px;
            line-height: 100%;
            background-color: blueviolet;
        }
    </style>
</head>

<body>
    <!-- <div style="width:100%;height:100%;">width:100%;height:100%;</div> -->
    <div style="height:100%;">height:100%;</div>
    <!-- <div style="width:100%;height:200px;">width:100%;height:200px;</div> -->
</body>

</html>

全部代碼如上,可以看到設置了line-height為100%沒有居中,這是為什么呢,因為這時候的%是相對于字體尺寸的?所以直接作用于沒有絕對高度的元素是不行的。

line-height屬性說明:https://www.w3school.com.cn/cssref/pr_dim_line-height.asp

這時候要想居中,可以如下,做一個div嵌套,一個負責高度,一個負責居中,雖然感覺并不會這樣用到,但是居中還是很靈驗的~

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        html,
        body {
            height: 100%;
            margin: 0;
            padding: 0;
        }

        .div1 {
            background-color: blueviolet;
            position: relative;
        }

        .div2 {
            font-size: 30px;    
            color: white;
            text-align: center;                    
            width: 400px;
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translateX(-50%)  translateY(-50%);
        }
    </style>
</head>

<body>
    <!-- <div style="width:100%;height:100%;">width:100%;height:100%;</div> -->
    <div style="height:100%;" class="div1">
        <div class="div2">height:100%;</div>
    </div>
    <!-- <div style="width:100%;height:200px;">width:100%;height:200px;</div> -->
</body>

</html>

6.源碼

https://github.com/JiaXinYi/ife-study/blob/master/height/height.html

搬運鏈接:

(...) 前端小知識--為什么你寫的height:100%不起作用?_知其所以然——前端 - SegmentFault 思否

到此這篇關于為什么你寫的height:100%不起作用 的文章就介紹到這了,更多相關height:100%不起作用內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持腳本之家!

標簽:咸陽 文山 惠州 萍鄉(xiāng) 甘南 營口 蘇州 紅河

巨人網(wǎng)絡通訊聲明:本文標題《為什么你寫的height:100%不起作用》,本文關鍵詞  為什么,你,寫的,height,100%,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《為什么你寫的height:100%不起作用》相關的同類信息!
  • 本頁收集關于為什么你寫的height:100%不起作用的相關信息資訊供網(wǎng)民參考!
  • 推薦文章