不写<!DOCTYPE html>后父元素未设置高度,子元素height:100%时,继承祖先元素高度

一、父元素未设置高度,子元素height:100%却拥有祖先的高度

1、问题描述

在排查内容超出容器后,滚动轴不出现但能进行滚动的问题时,发现在下面这个结构中,背景为red的div居然持有200px的高度 (在实际问题中,相当于滚动内容的父容器;height:100%是平台封装样式,不能随意修改)。

如下图所示:由于父容器没有设置高度,而高度不会默认继承,所以red的高度也应该为0px。

css 复制代码
<div style="height: 200px; background: pink;">
    <div>
        <div>
            <div style="height: 100%; background: red"></div>
        </div>
    </div>
</div>

而正常情况下,应该呈现的效果为

2、初见端倪

  • 开始一度以为是样式问题,故而一直盯着仅有的样式查看,属实排查不出来。并且在网上也没有查到类似问题,由于其他类似结构是正常的,于是开始在控制台对比多个相同结构html源文件。
  • 最后发现异常页面是由一个temp.html通过请求获取需要展示的html后,使用document.write方法写入的。而temp.html仅包含一个script标签:
temp.html 复制代码
<script>document.write('target html structure')<script>

document.write将目标html结构插入temp.html,最终会将上述script标签保留在结构中。

本以为是script标签阻塞样式加载的问题,在后面的测试中发现原来是<!DOCTYPE html>原因。

3、反思与总结

众所周知,"是为了向浏览器表明当前文档应该使用html5标准来解析"。

如果不写,或者少写都会导致浏览器以其他标准解析文档。

这也就是此次问题的根本原因。

归根结底,还是基础不牢,规则意识不强。

二、一点document.write的总结

说实话,document.write一直让我很疑惑。查资料,大家都说他会清空已打开文档的全部内容。那么打开这一词用什么代码去区别呢?

相比之下,MDN确实更显专业一些,说他会在已完成加载的文档调用时,清空所有内容。
加载一词很熟悉,让我想到了window.onload方法:它在文档资源加载完毕后使用。事实证明确实如此,将write放在onload中执行就会替换当前文档内容。

相关推荐
小小前端--可笑可笑1 分钟前
Vue / React 单页应用刷新 /login 无法访问问题分析
运维·前端·javascript·vue.js·nginx·react.js
小林敲代码778825 分钟前
记一次 Vue 项目首屏优化:从 7.1s 到 0.9s,深挖 Gzip 的力量
前端·javascript·vue.js
前端大卫31 分钟前
写给年轻程序员的几点小建议
前端
NEXT061 小时前
React 闭包陷阱深度解析:从词法作用域到快照渲染
前端·react.js·面试
脱离语言2 小时前
Jeecg3.8.2 前端经验汇总
开发语言·前端·javascript
NEXT062 小时前
useMemo 与 useCallback 的原理与最佳实践
前端·javascript·react.js
小爱丨同学2 小时前
React-Context用法汇总 +注意点
前端·javascript·react.js
徐同保3 小时前
python如何手动抛出异常
java·前端·python
极客小云3 小时前
【实时更新 | 2026年国内可用的npm镜像源/加速器配置大全(附测速方法)】
前端·npm·node.js
半兽先生4 小时前
告别 AI 乱写 Vue!用 vue-skills 构建前端智能编码标准
前端·vue.js·人工智能