css 如何设置图片不超出显示?

html-css021

css 如何设置图片不超出显示?,第1张

外围容器给固定宽度,不指定高度或高度auto(此时需要设置overflow:hidden)。

例:

.photoContainer { width:700px}

.photoContainer li { width:200pxheight:200pxmargin:10px 0 0 10pxoverflow:hiddenfloat:left}

.photoContainer li img { width:180pxheight:180px}

<ul class="photoContainer">

<li><a href="#" target="_blank"><img src="images/1.jpg" ></a></li>

<li><a href="#" target="_blank"><img src="images/2.jpg" ></a></li>

<li><a href="#" target="_blank"><img src="images/3.jpg" ></a></li>

<li><a href="#" target="_blank"><img src="images/1.jpg" ></a></li>

<li><a href="#" target="_blank"><img src="images/2.jpg" ></a></li>

<li><a href="#" target="_blank"><img src="images/3.jpg" ></a></li>

</ul>

就是上面说的那样啊。

外围容器给固定宽度,不指定高度或高度auto(此时需要设置overflow:hidden)。

太久没用的东西,偶然用到,竟然忘记了,所以记录一下,加深一下印象

图片和行内块元素默认底线会和父级盒子的基线对齐,因此就会产生白色缝隙。

1.用vertical-align:middle | top| bottom等,让图片不和基线对齐。

上面3中对齐方式都可以

vertical-align不影响块级元素中的内容对齐,它只针对于行内元素或者行内块元素,特别是行内块元素, 通常用来控制图片/表单与文字的对齐。

2.将img通过display: block转为块级元素。

转为块级元素之后,就不存在和父级盒子基线对齐的问题了。

用background-size属性,你想给他多大的百分比都可以,不设置表示默认图片大小,设置100%表示全屏显示图片,按比例缩小或者放大。

这样就可以实现背景图片自适应父容器大小而自动变化,达到填充效果。 但是,图片会被拉伸填充,这并不是我们想要的效果,那么我们可以不设置 100% 参数,而是使用 cover 参数。

设置cover参数以后,背景图会按比例缩放填充满整个背景。如果使用IE浏览器你会发现,上面的 background-size:100% 100% 并没有起到作用,图片原本是怎样就怎样显示,比较大就只能显示一部分。

所以这时需要使用IE特有的滤镜 AlphaImageLoader 兼容性在IE5.5+以上版本的浏览器上都可以完美运行。

1、enabled: 可选项。布尔值(Boolean)。设置或检索滤镜是否激活。true | false_ true: 默认值。滤镜激活。

2、false: 滤镜被禁止。

3、sizingMethod: 可选项。字符串(String)。设置或检索滤镜作用的对象的图片在对象容器边界内的显示方式。

4、crop: 剪切图片以适应对象尺寸。

5、image: 默认值。增大或减小对象的尺寸边界以适应图片的尺寸。

6、scale: 缩放图片以适应对象的尺寸边界。

7、src: 必选项。字符串(String)。使用绝对或相对 url 地址指定背景图像。假如忽略此参数,滤镜将不会作用。

特性:

1、Enabled: 可读写。布尔值(Boolean)。参阅 enabled 属性。

2、sizingMethod: 可读写。字符串(String)。参阅 sizingMethod 属性。

3、src: 可读写。字符串(String)。参阅 src 属性。

说明:

在对象容器边界内,在对象的背景和内容之间显示一张图片。并提供对此图片的剪切和改变尺寸的操作。如果载入的是PNG格式,则0%-100%的透明度也被提供。

PNG格式的图片的透明度不妨碍你选择文本。也就是说,你可以选择显示在PNG格式的图片完全透明区域后面的内容。这样我们就可以完美兼容绝大多数的浏览器,实现用CSS让背景图片100%填充了。