【前端面试的坑】HTML行内置换元素与非置换元素的区分
作者:互联网
一个 内容 不受CSS视觉格式化模型控制,CSS渲染模型并不考虑对此内容的渲染,且元素本身一般拥有固有尺寸(宽度,高度,宽高比)的元素,被称之为置换元素。
也可以理解为,浏览器根据元素的标签和属性,来决定元素的具体显示内容。
例如:浏览器根据标签的src属性显示图片。根据标签的type属性决定显示输入框还是按钮。
置换元素在其显示中生成了框,这也就是有的内联元素能够设置宽高的原因。
html中的<img>
、<input>
、<textarea>
、<select>
、<object>
都是置换元素,这些置换元素往往没有实际内容,即是一个空元素。
w3c并没有给出明确的非置换元素的解释,但能确定的是除置换元素之外,所有的元素都是非置换元素。
浏览器中的大多数元素都是非置换元素,即其内容直接展示给浏览器。
例如标签,
标签里的内容会被浏览器直接显示给用户。
行内级置换和非置换元素的宽度定义对于行内级非置换元素,宽度设置是不适用的。
对于行内级置换元素来说,其宽度的设置需遵循以下几点:
-
若宽高的计算值都为 auto 且元素有固有宽度,则 width 的使用值为该固有宽度;
典型的例子是:拥有默认宽高的 input 当宽度的计算值为auto时,则宽度使用值为其默认的固有宽度
-
若宽度的计算值为 auto 且元素有固有宽度,则 width 的使用值为该固有宽度;
例子同上
-
若宽度的计算值为 auto 且高度有 非auto 的计算值,并且元素有固有宽高比,则 width 的使用值为 高度使用值 * 固有宽高比;
典型的例子:img 当只定义了其高度值时,其宽度将会根据固有宽高比进行等比设置
-
除此之外,当 width 的计算值为 auto 时,则宽度的使用值为 300px
典型的例子:比如iframe, canvas这里是引用
其它类型的置换元素,其宽度的定义都参照行内置换元素的定义。
行内级置换和非置换元素的高度定义对于行内级非置换元素,高度设置是不适用的。
对于行内级置换元素来说,其高度的设置需遵循以下几点:
- 若宽高的计算值都为 auto 且元素有固有高度,则 height 的使用值为该固有高度;
- 若高度的计算值为 auto 且元素有固有高度,则 height 的使用值为该固有高度;
- 若高度的计算值为 auto 且宽度有 非auto 的计算值,并且元素有固有宽高比,则 height 的使用值为:宽度使用值 / 固有宽高比;
- 若高度的计算值为 auto 且上述条件完全不符,则 height 的使用值 不能大于150px,且宽度不能大于长方形高度的2倍。
其它类型的置换元素,其高度的定义都参照行内置换元素的定义。
标签:HTML,auto,置换,元素,值为,宽度,固有 来源: https://blog.51cto.com/u_14785218/2878573