微信小程序圖片加載

微信小程序里面顯示圖片會用到 image 組件,該組件默認寬度300px斜棚、高度225px阀蒂,使用時需要自己設(shè)置寬度 width、高度 height 以及圖片資源地址 src弟蚀。當(dāng)圖片資源為本地圖片時蚤霞,可以先查看其寬高,再設(shè)置為 image 的 width 和 height义钉,但是當(dāng)圖片是從網(wǎng)絡(luò)上加載昧绣,并不能提前確定其寬高時,需要考慮怎樣才能使其自動適應(yīng)寬高捶闸,并按期望顯示滞乙。

image 有一個 mode 屬性,該屬性有 13 種模式鉴嗤,其中 4 種是縮放模式序调,9 種是裁剪模式:

縮放模式:
scaleToFill    不保持縱橫比縮放圖片醉锅,使圖片的寬高完全拉伸至填滿 image 元素
aspectFit    保持縱橫比縮放圖片,使圖片的長邊能完全顯示出來发绢。也就是說边酒,可以完整地將圖片顯示出來坯认。
aspectFill    保持縱橫比縮放圖片引润,只保證圖片的短邊能完全顯示出來痒玩。也就是說缆毁,圖片通常只在水平或垂直方向是完整的,另一個方向?qū)l(fā)生截取。
widthFix    寬度不變浇雹,高度自動變化,保持原圖寬高比不變

裁剪模式:
top    不縮放圖片祝旷,只顯示圖片的頂部區(qū)域
bottom    不縮放圖片吻谋,只顯示圖片的底部區(qū)域
center    不縮放圖片戒祠,只顯示圖片的中間區(qū)域
left    不縮放圖片栋操,只顯示圖片的左邊區(qū)域
right    不縮放圖片闸餐,只顯示圖片的右邊區(qū)域
top left    不縮放圖片,只顯示圖片的左上邊區(qū)域
top right    不縮放圖片,只顯示圖片的右上邊區(qū)域
bottom left    不縮放圖片,只顯示圖片的左下邊區(qū)域
bottom right    不縮放圖片烈疚,只顯示圖片的右下邊區(qū)域        

一般情況下從網(wǎng)絡(luò)上加載圖片時黔牵,由于圖片的尺寸未知,為了防止圖片過寬或過長爷肝,因此不會完全按照圖片的尺寸設(shè)置寬高荧止,而是給定一個最大的寬度和高度,目標(biāo)是將圖片按照原始比例并在合適的可視范圍內(nèi)顯示阶剑。
首先為 image 的 bindload 屬性綁定一個方法,該方法會在圖片加載完成時調(diào)用危号,從而獲取圖片尺寸牧愁,當(dāng)圖片尺寸獲取到后,根據(jù)最大寬高計算最終的尺寸外莲,并保存在 data 中定義的數(shù)據(jù)中猪半,之后在 image 中通過 style 屬性將 width 和 height 設(shè)置為保存的數(shù)據(jù)即可。另外由于圖片可能加載失敗偷线,那么可以綁定binderror屬性磨确,在加載失敗時設(shè)置 width 和 height,避免 image 的尺寸不符合預(yù)期声邦,也可以在 data 中設(shè)置期望的加載失敗時的寬高乏奥。代碼如下:

<image src="{{pic}}" style="width:{{picSize.width}}rpx;height:{{picSize.height}}rpx;" bindload="imageLoad" />
Page({
  data: {
    picSize: { "width": 320, "height": 320}
  },
  imageLoad: function (e) {
    var maxSize = 320;
    var imgWidth = e.detail.width;
    var imgHeight = e.detail.height;
    var ratio = imgWidth / imgHeight;
    var picSize;
    if (imgWidth >= imgHeight && imgWidth > maxSize) {
      // 如果是寬圖并且寬度超過最大寬度,則以最大寬度作為最終寬度并按原始比例計算高度
      picSize = { "width": maxSize, "height": maxSize/ ratio };
    } else if (imgHeight > imgWidth && imgHeight > maxSize) {
      // 如果是長圖并且高度超過最大高度亥曹,則以最大高度作為最終高度并按原始比例計算寬度
      picSize = { "width": maxSize* ratio, "height": maxSize};
    } else {
      // 如果寬高都在最大限度之內(nèi)則最終寬高為圖片的原始尺寸
      picSize = { "width": imgWidth, "height": imgHeight };
    }
    this.setData({
      picSize: picSize
    })
  }
})
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末邓了,一起剝皮案震驚了整個濱河市恨诱,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌骗炉,老刑警劉巖照宝,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異句葵,居然都是意外死亡厕鹃,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進店門乍丈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來剂碴,“玉大人,你說我怎么就攤上這事诗赌『骨眩” “怎么了?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵铭若,是天一觀的道長洪碳。 經(jīng)常有香客問我,道長叼屠,這世上最難降的妖魔是什么瞳腌? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮镜雨,結(jié)果婚禮上嫂侍,老公的妹妹穿的比我還像新娘。我一直安慰自己荚坞,他們只是感情好挑宠,可當(dāng)我...
    茶點故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著颓影,像睡著了一般各淀。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上诡挂,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天碎浇,我揣著相機與錄音,去河邊找鬼璃俗。 笑死奴璃,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的城豁。 我是一名探鬼主播苟穆,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了鞭缭?” 一聲冷哼從身側(cè)響起剖膳,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎岭辣,沒想到半個月后吱晒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡沦童,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年仑濒,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片偷遗。...
    茶點故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡墩瞳,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出氏豌,到底是詐尸還是另有隱情喉酌,我是刑警寧澤,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布泵喘,位于F島的核電站泪电,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏纪铺。R本人自食惡果不足惜相速,卻給世界環(huán)境...
    茶點故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望鲜锚。 院中可真熱鬧突诬,春花似錦、人聲如沸芜繁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽骏令。三九已至蔬捷,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間伏社,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工塔淤, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留摘昌,地道東北人。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓高蜂,卻偏偏與公主長得像聪黎,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,925評論 2 344

推薦閱讀更多精彩內(nèi)容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案稿饰? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J的外補...
    _Yfling閱讀 13,728評論 1 92
  • 選擇qi:是表達式 標(biāo)簽選擇器 類選擇器 屬性選擇器 繼承屬性: color锦秒,font,text-align喉镰,li...
    wzhiq896閱讀 1,731評論 0 2
  • 選擇qi:是表達式 標(biāo)簽選擇器 類選擇器 屬性選擇器 繼承屬性: color旅择,font,text-align侣姆,li...
    love2013閱讀 2,303評論 0 11
  • 前言 學(xué)習(xí)本系列內(nèi)容需要具備一定 HTML 開發(fā)基礎(chǔ)生真,沒有基礎(chǔ)的朋友可以先轉(zhuǎn)至 HTML快速入門(一) 學(xué)習(xí) 本人...
    珍此良辰閱讀 20,653評論 15 16
  • 翻譯自“Auto Layout Guide”。 2 自動布局細則手冊 2.1 堆棧視圖 接下來的章節(jié)展示了如何使用...
    lakerszhy閱讀 1,853評論 3 9