问题描述:在使用微信小程序image组件的时候,在不确定图片宽高情况下 想给一个最大宽度让图片自适应,按比例,image的widthfiex和heightFiex并不能满足(只指定最大宽/高并不会生效)
问题解决:使用bindload获取图片信息获取宽高再判断是否超过最大值
html
<image class="bubbleImg" src="{{imageUrl}}" bindload="onImageLoad" style="width: {{imgWidth || 0}}px;" mode="widthFix"></image>
js
//获取图片宽度
onImageLoad(event) {
var { width } = event.detail;
const key = event.currentTarget.dataset.key;
if(width>200){ //最大值为200px
width=200
}
this.setData({
imgWidth : width;
})
},