主頁(yè) > 知識(shí)庫(kù) > 為什么你寫的height:100%不起作用

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

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

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

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

1.百分比寬高的設(shè)定

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

2.width:100%;

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

<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%很容易就實(shí)現(xiàn)的,但是這里的height卻不能設(shè)置成%比的(該元素會(huì)消失看不見),這是為什么呢?

3.瀏覽器是如何計(jì)算高度和寬度的

Web瀏覽器在計(jì)算有效寬度時(shí)會(huì)考慮瀏覽器窗口的打開寬度。如果你不給寬度設(shè)定任何缺省值,那瀏覽器會(huì)自動(dòng)將頁(yè)面內(nèi)容平鋪填滿整個(gè)橫向?qū)挾?。即我們不設(shè)置寬,會(huì)自動(dòng)填滿整個(gè)橫向?qū)挾?,如下?/p>

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

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

4.如何解決

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

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

5.關(guān)于line-height居中的一點(diǎn)誤解?

<!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>

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

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

這時(shí)候要想居中,可以如下,做一個(gè)div嵌套,一個(gè)負(fù)責(zé)高度,一個(gè)負(fù)責(zé)居中,雖然感覺并不會(huì)這樣用到,但是居中還是很靈驗(yàn)的~

<!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

搬運(yùn)鏈接:

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

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

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

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