首頁 >web前端 >js教程 >在微信小程式中如何實作image元件圖片自適應顯示

在微信小程式中如何實作image元件圖片自適應顯示

亚连
亚连原創
2018-06-11 16:53:503286瀏覽

這篇文章主要介紹了微信小程式實現image元件圖片自適應寬度比例顯示的方法,簡單講述了image元件的常用屬性,並結合實例形式分析了微信小程式實現圖片自適應寬度比例的相關操作技巧,需要的朋友可以參考下

本文實例講述了微信小程式實作image元件圖片自適應寬度比例顯示的方法。分享給大家供大家參考,具體如下:

一. 了解image元件

##由於image有預設的固定的寬度和高度,這樣我們在做圖片自適應的時候,就不好做了。下面就來一起解決下

二.方法

#(一).使用mode:widthFix

#widthFix:寬度不變,高度自動變化,原圖寬高比不變。

首先我們先設定image的mode為widthFix,然後再為圖片加上一個固定rpx的寬度,例如:730rpx。

這樣圖片也可以自適應了。 。因為小程式的rpx本身就是一個自適應顯示的單位

(二).使用bindload綁定函式動態自適應。

我們可以給image綁定一個函數,這個函數,如上面的bindload說明一樣,我們可以取得到原圖的寬度和高度。

然後計算他們的寬高比率。 。然後設定一個寬度大小(rpx),最後透過style動態設定image的寬高。程式碼如下:

1. 寫頁面結構index.wxml:

<image src="../uploads/2.jpg" bindload="imageLoad"
style="width:{{imgwidth}}rpx; height:{{imgheight }}rpx;"></image>

2. 設定資料index.js

//获取应用实例
var app = getApp()
Page({
  data: {
    screenWidth: 0,
    screenHeight:0,
    imgwidth:0,
    imgheight:0,
  },
  onLoad: function() {
    var _this = this;
    wx.getSystemInfo({
      success: function(res) {
        _this.setData({
          screenHeight: res.windowHeight,
          screenWidth: res.windowWidth,
        });
      }
    });
  },
  imageLoad: function(e) {
    var _this=this;
    var $width=e.detail.width,  //获取图片真实宽度
      $height=e.detail.height,
      ratio=$width/$height;  //图片的真实宽高比例
    var viewWidth=500,      //设置图片显示宽度,
      viewHeight=500/ratio;  //计算的高度值
    this.setData({
      imgwidth:viewWidth,
      imgheight:viewHeight
    })
  }
})

##上面是我整理給大家的,希望未來對大家有幫助。

相關文章:

在vue中將物件新增的屬性加入檢測序列的方法有哪些?

在jQuery中實現碰到邊緣反彈的動畫效果該如何做?

在vue cli webpack中如何使用sass(詳細教學)

在jQuery如何改變P標籤文字值

#在jQuery中實作標籤子元素的新增與賦值方法

#透過在js動態中建立標籤,並設定屬性方法(詳細教學)

以上是在微信小程式中如何實作image元件圖片自適應顯示的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn