今天学习微信小程序开发的image组件,mode属性的属性值不少,一开始有点整不明白。后来从网上下载了一张图片,把每个属性都试验了一番,总算明白了。现总结归纳如下:
1.使用scaleToFill。这是mode的默认值,scaleToFill会让图片变形,效果见下图,但是图片能完整显示。
html
<image src="/images/luban.jpg" mode="scaleToFill" />
data:image/s3,"s3://crabby-images/adb2e/adb2efddea0e5f93cd9ccc8f1c86e24d512a725c" alt=""
2.使用aspectFit属性值,实现image组件在保持图片宽高比不变的情况下使图片长边能够完全显示出来,图片完整显示,图片不变形。这里都是和默认值scaleToFill作对比。
<image src="/images/luban.jpg" mode="aspectFit" />
data:image/s3,"s3://crabby-images/03e48/03e48e72a0209d17c5e6feab39fc5130109de119" alt=""
3.使用aspectFill属性,实现image组件在保持图片宽高比不变的情况下,使图片短边能够完全显示出来,另一边不完整显示。这里可以看到,鲁班的头部没有显示完整,图片不变形。
<image src="/images/luban.jpg" mode="aspectFill" />
data:image/s3,"s3://crabby-images/8dc23/8dc23a05e60b92ad06c05a3a619231c26245d1f3" alt=""
4.使用widthFix属性,image组件保持图片宽高比不变的情况下,图片宽度不变,高度自动变化,图片完整显示。
<image src="/images/luban.jpg" mode="widthFix" />
data:image/s3,"s3://crabby-images/df8cd/df8cd19f1430856cefd676bf5a8bf4606f99444f" alt=""
5.使用heightFix属性,image组件保持图片宽高比不变的情况下,图片高度不变,宽度自动变化。图片完整显示。高度定了,宽度由高度决定,也就是图片不变形,等比例变化。图片整体看上去比上一张图片4小。
<image src="/images/luban.jpg" mode="heightFix" />
data:image/s3,"s3://crabby-images/2b8e1/2b8e115bed54288713cb3e0699db1ab7936e6154" alt=""
下面是mode取值为top、bottom、center、left、right等,我也逐一做了验证,这里没有什么不好理解的。以top和bottom left为例,效果图如下。
<image src="/images/luban.jpg" mode="top" />
data:image/s3,"s3://crabby-images/a6334/a633410a81c615313f324f0f355e4af6cd555bf2" alt=""
<image src="/images/luban.jpg" mode="bottom right" />
data:image/s3,"s3://crabby-images/e2f2b/e2f2bb5421ce1d7bbf2258ad0f8ab12badb6123b" alt=""
都说实践出真知,感觉有一些懵懵懂懂,模糊不清的地方,自己动手实践一下,基本就会理解。