margin/padding 数值为百分比时为什么是以父元素的宽度计算而不是高度?

1、问题描述:

            给子元素设置 margin-top 是 10%,则这个百分比的基数是父元素的宽度。

2、问题解析:

            当margin/padding取形式为百分比的值时,无论是left/right,还是top/bottom,都是以父元素的width为基数进行渲染的。

            比较有说服力的一种说法是,父元素的高度往往由子元素来决定,如果margin-top比例增加,相应的,父元素高度也会进行适应性增加,此时父元素增加的同时,margin-top的实际数值又会发生适应性变化,双向因果会造成循环,所以W3C的规范做出了以上规定。

在查询资料的过程中,有人提出,如果子元素高度确定的情况下,只要给出margin-top的比例数值,就可以通过数学公式得到父元素高度的数值,不存在循环。个人感觉即使子元素高度确定,父元素高度也已经确定了,父元素的自适应根据子元素直接适应,在margin/padding设置过程中,父元素已经确定,肯定会直接抓取父元素高度数据进行渲染,渲染结果也必然会造成margin/padding数值的偏差。说能计算出父元素高度并进行渲染的是不是忽略了网页元素渲染的先后与主次,也许高估了网页渲染的智能程度,真正原因是什么,其实不必太纠结,W3C提出了标准,我们按标准进行开发即可。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,868评论 1 92
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,958评论 1 45
  • day01­_起源和结构 结构:Xhtml xml 表现:CSS 行为:DOM ECMAScript 以上都属于W...
    Sakura_明妃阅读 1,263评论 0 1
  • •前端面试题汇总 一、HTML和CSS 21 你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么? ...
    Simon_s阅读 2,241评论 0 8
  • 【0623我在悦读】超有才华 书名:精进 作者:采铜 篇目:每一个成功者,都是唯一的 金句: 当我们避开了追求社会...
    超有才华阅读 218评论 0 1