成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

微信小程序中image圖片加載完成監(jiān)聽的方法-創(chuàng)新互聯(lián)

本篇內(nèi)容主要講解“微信小程序中image圖片加載完成監(jiān)聽的方法”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“微信小程序中image圖片加載完成監(jiān)聽的方法”吧!

成都創(chuàng)新互聯(lián)公司是一家專注于成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)與策劃設(shè)計(jì),古丈網(wǎng)站建設(shè)哪家好?成都創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設(shè)10多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:古丈等地區(qū)。古丈做網(wǎng)站價(jià)格咨詢:18982081108

需求

在應(yīng)用中顯示的圖片很多情況不滿足業(yè)務(wù)需求,我們需要?jiǎng)討B(tài)根據(jù)圖片的寬高進(jìn)行縮放或加載中顯示的缺省圖片,這是我沒就需要監(jiān)聽圖片加載完成回調(diào),來看看微信小程序怎么實(shí)現(xiàn)圖片加載完成回調(diào)。

實(shí)現(xiàn)

1. 綁定回調(diào)

通過image標(biāo)簽的bindload屬性綁定圖片加載完成回調(diào)函數(shù),src根據(jù)圖片加載是否完成綁定是否顯示缺省圖:

<image src='{{loadComplete?srcImagePath:defaultImagePath}}' bindload="imageLoad"/>

2. 回調(diào)監(jiān)聽

在js文件中定一個(gè)imageLoad函數(shù),我們就可以通過參數(shù)拿到圖片加載完成寬高信息:

imgOnLoad(ev) {
  let src = ev.currentTarget.dataset.src,
   width = ev.detail.width,
   height = ev.detail.height
 }

3. 縮放圖片

我們寫一個(gè)工具類,然后調(diào)用imageUtil方法對(duì)原始圖片根據(jù)屏幕寬高進(jìn)行等比例縮放。

function imageUtil(e) {
 var imageSize = {};
 var originalWidth = e.detail.width;//圖片原始寬 
 var originalHeight = e.detail.height;//圖片原始高 
 var originalScale = originalHeight / originalWidth;//圖片高寬比 
 console.log('originalWidth: ' + originalWidth)
 console.log('originalHeight: ' + originalHeight)
 imageSize.imageWidth = originalWidth;
 imageSize.imageHeight = originalHeight;
 //獲取屏幕寬高 
 wx.getSystemInfo({
  success: function (res) {
   var windowWidth = res.windowWidth;
   var windowHeight = res.windowHeight;
   var windowscale = windowHeight / windowWidth;//屏幕高寬比 
   if (originalScale < windowscale) {//圖片高寬比小于屏幕高寬比 
    //圖片縮放后的寬為屏幕寬 
    imageSize.imageWidth = windowWidth;
    imageSize.imageHeight = (windowWidth * originalHeight) / originalWidth;
   } else {//圖片高寬比大于屏幕高寬比 
    //圖片縮放后的高為屏幕高 
    imageSize.imageHeight = windowHeight;
    imageSize.imageWidth = (windowHeight * originalWidth) / originalHeight;
   }
   imageSize.imageWidth = windowWidth;
   imageSize.imageHeight = windowHeight;
  }
 })
 console.log('縮放后的寬: ' + imageSize.imageWidth)
 console.log('縮放后的高: ' + imageSize.imageHeight)
 return imageSize;
}

4. 修改image寬高

通過imageUtil獲取到目標(biāo)寬高后,this.setData({width:imageUtil(e).width, height:imageUtil(e).height}) 即可以動(dòng)態(tài)修改圖片寬高了(e是imageLoad方法中的參數(shù)):

<image src='{{loadComplete?srcImagePath:defaultImagePath}}' bindload="imageLoad" style='width:width;height:height'/>

到此,相信大家對(duì)“微信小程序中image圖片加載完成監(jiān)聽的方法”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

分享標(biāo)題:微信小程序中image圖片加載完成監(jiān)聽的方法-創(chuàng)新互聯(lián)
鏈接分享:http://jinyejixie.com/article28/jjocp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)網(wǎng)站策劃、網(wǎng)站收錄、微信公眾號(hào)域名注冊(cè)、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

營(yíng)銷型網(wǎng)站建設(shè)
衡南县| 宜川县| 比如县| 门源| 安顺市| 望都县| 夏津县| 岳普湖县| 吉首市| 景德镇市| 梁山县| 兴和县| 林周县| 法库县| 凤台县| 称多县| 石台县| 柳州市| 丹凤县| 朔州市| 孙吴县| 灵丘县| 余干县| 勃利县| 沛县| 日喀则市| 南充市| 翁牛特旗| 耿马| 蓬安县| 阳城县| 阳谷县| 松原市| 治县。| 卢龙县| 邵东县| 博客| 泽库县| 英超| 武隆县| 正镶白旗|