小编给大家分享一下如何解决img标签设置display:block属性时宽度无法设定为100%的问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
如下代码,img标签设置了display:block,尺寸宽度无法设定为100%
<!DOCTYPEhtml>
<htmllang="en">
<head>
<metacharset="UTF-8">
<title>img标签设置display:block,宽度无法100%</title>
</head>
<body>
<p>
<imgsrc="https://www.baidu.com/img/bd_logo1.png?where=super"style="display:block;">
</p>
</body>
</html>
原因
替换元素和非替换元素
元素是文档结构的基础,在CSS中,每个元素生成了一个包含了元素内容的框(box,也翻译为“盒子”)。但是不同的元素显示的方式会有所不同,例如p和span不同,而strong和p也不一样。在文档类型定义(DTD)中对不同的元素规定了不同的类型,这也是DTD对文档之所以重要的原因之一。而根据元素本身的特点可以分为替换元素(replacedelement)和非替换元素,非替换元素,在W3C中没有给出明确的定义,但我们可以由替换元素对应着非替换元素,所以可以理解为除了替换元素,其它的就是非替换元素
替换元素:浏览器根据元素的标签和属性,来决定元素的具体显示内容。替换元素是其内容不受CSS视觉格式化模型控制的元素,例如img标签,嵌入的文档(iframe之类)或者applet,这些叫做替换元素。比如img元素通过src属性的值来读取图片信息并显示出来,而如果查看(x)html代码,却看不到图片的实际内容,而且img元素的内容通常会被src属性指定的图像替换掉;例如input元素的type属性决定是显示输入框,还是单选按钮等。(x)html中的img,input,textarea,select,object都是替换元素。这些元素没有实际的内容,即是个空元素
非替换元素:(X)HTML的大多数元素是非替换元素,他们将内容直接告诉浏览器,将其显示出来
img标签为替换元素,替换元素的特性之一就是尺寸由内部元素决定,且无论其display属性值是inline还是block。这个特性很有意思,对于非替换元素,如果其display属性值为block,则会具有流动性,宽度由外部尺寸决定,但是替换元素的宽度却不受display水平影响,因此,display水平是无法让尺寸100%自适应父容器的
解决
解决办法就是,通过设定<img>的width尺寸100%
<!DOCTYPEhtml>
<htmllang="en">
<head>
<metacharset="UTF-8">
<title>img标签设置display:block,宽度无法100%</title>
</head>
<body>
<p>
<imgsrc="https://www.baidu.com/img/bd_logo1.png?where=super"style="display:block;width:100%;">
</p>
</body>
</html>
看完了这篇文章,相信你对“如何解决img标签设置display:block属性时宽度无法设定为100%的问题”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。