微信小程序動態(tài)設(shè)置圖片大小的方法
我們都知道微信小程序的組件image是用來顯示圖片的,它有一下幾個屬性:
1、src 圖片資源地址
2、mode 圖片裁剪、縮放的模式
3、binderror 當(dāng)錯誤發(fā)生時,發(fā)布到 AppService 的事件名,事件對象event.detail = {errMsg: ‘something wrong'}
4、bindload 當(dāng)圖片載入完畢時,發(fā)布到 AppService 的事件名,事件對象event.detail = {height:'圖片高度px', width:'圖片寬度px'}
但是image有默認(rèn)的固定的寬度和高度,這樣我們在做圖片自適應(yīng)的時候,就不好做了,特別是我們在做一些商品詳情頁的時候,需要image自適應(yīng)屏幕,按原圖比例顯示。那么如何讓image自適應(yīng)比例顯示呢?可以有兩種方法:
一、使用mode:widthFix
widthFix:寬度不變,高度自動變化,保持原圖寬高比不變。
首先我們先設(shè)置image的mode為widthFix,然后給圖片加一個固定rpx的寬度,比如:730rpx。
這樣圖片也可以自適應(yīng)了。。因為小程序的rpx本身就是一個自適應(yīng)顯示的單位
二、使用bindload綁定函數(shù)動態(tài)自適應(yīng)。
我們可以給image綁定一個函數(shù),這個函數(shù),如上面的bindload說明一樣,我們可以獲取到原圖的寬度和高度。
然后計算他們的寬高比率。。然后設(shè)置一個寬度大?。╮px),最后通過style動態(tài)設(shè)置image的寬高。代碼如下:
html代碼:
<image src="{{ item }}" bindload="imageLoad" data-index="{{ index }}"
style="width:{{ images[index].width }}rpx; height:{{ images[index].height }}rpx;"></image>
js代碼:
Page({
data: {
images:{}
},
imageLoad: function(e) {
var $width=e.detail.width, //獲取圖片真實寬度
$height=e.detail.height,
ratio=$width/$height; //圖片的真實寬高比例
var viewWidth=718, //設(shè)置圖片顯示寬度,左右留有16rpx邊距
viewHeight=718/ratio; //計算的高度值
var image=this.data.images;
//將圖片的datadata-index作為image對象的key,然后存儲圖片的寬高值
image[e.target.dataset.index]={
width:viewWidth,
height:viewHeight
}
this.setData({
images:image
})
}
})
最后,我們就可以可以通過images[index].width 和 images[index].height給每一個圖片設(shè)置寬高了。
效果如下圖所示:

總結(jié)
以上所述是小編給大家介紹的微信小程序動態(tài)設(shè)置圖片大小的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
基于JavaScript實現(xiàn)鼠標(biāo)懸浮彈出跟隨鼠標(biāo)移動的帶箭頭的信息層
這篇文章主要介紹了基于JavaScript實現(xiàn)鼠標(biāo)懸浮彈出跟隨鼠標(biāo)移動的帶箭頭的信息層 的相關(guān)資料,需要的朋友可以參考下2016-01-01
JS中利用swiper實現(xiàn)3d翻轉(zhuǎn)幻燈片實例代碼
也說JavaScript中String類的replace函數(shù)

