ant Design 中的 a-image 没有 mode 的解决办法

1,353 阅读1分钟

我使用的是 2.x 版本的 ant Design 组件库,想要规定一个图片大小,还需要预览功能。

使用了组件库中的 <a-image> 组件,但是这个组件没有 mode 属性,也就是不能设置是短边占满,长边裁掉等模式。

解决方案:

使用css中的 object-fit 属性来处理:

.一个父级class .ant-image .ant-image-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

object-fit

object-fit 属性指定元素的内容应该如何去适应指定容器的高度与宽度。

object-fit 一般用于 img 和 video 标签,一般可以对这些元素进行保留原始比例的剪切、缩放或者直接进行拉伸等。

描述尝试一下
fill默认,不保证保持原有的比例,内容拉伸填充整个内容容器。尝试一下 »
contain保持原有尺寸比例。内容被缩放。尝试一下 »
cover保持原有尺寸比例。但部分内容可能被剪切。尝试一下 »
none保留原有元素内容的长度和宽度,也就是说内容不会被重置。尝试一下 »
scale-down保持原有尺寸比例。内容的尺寸与 none 或 contain 中的一个相同,取决于它们两个之间谁得到的对象尺寸会更小一些。尝试一下 »
initial设置为默认值,关于 initial
inherit从该元素的父元素继承属性。 关于 inherit