微信小程序 swiper 轮播图片显示不全解决办法

微信小程序  swiper 轮播图片显示不全解决办法

     小程序中的轮播图很简单,官方都有例子的,但是唯一的缺陷就是swiper是固定死的150px高度,这样如果传入的图片大于这个高度就会被隐藏。那么,怎样让图片自适应不同分辨率捏。

  我的思路是:获取屏幕宽度,获取图片的宽高,然后等比设置当前屏幕宽度下swiper的高度。

<swiper indicator-dots="{{indicatorDots}}" autoplay="{{autoplay}}" interval="{{interval}}" duration="{{duration}}" indicator-active-color="{{bg}}"
style='height:{{Hei}}'> <block wx:for="{{imgUrls}}"> <swiper-item> <image src="{{item}}" class="slide-image" mode="widthFix" bindload='imgH'/>
//bindload是绑定图片加载的事件,记得给image加上mode=“widthFix”这个属性哦,还有就是设置这个image 100%宽度哟 </swiper-item> </block> </swiper>

  swiper的各个属性在官方文档中都有,这里就不说明了。最主要的是:  style='height:{{Hei}}' //动态设置swiper的高度 

js修改部分

data: {
    
    Hei:""          //这是swiper要动态设置的高度属性
 },
imgH:function(e){
    var winWid = wx.getSystemInfoSync().windowWidth;         //获取当前屏幕的宽度
    var imgh=e.detail.height;                //图片高度
    var imgw=e.detail.width;
    var swiperH=winWid*imgh/imgw + "px"          //等比设置swiper的高度。  即 屏幕宽度 / swiper高度 = 图片宽度 / 图片高度    ==》swiper高度 = 屏幕宽度 * 图片高度 / 图片宽度
    this.setData({
        Hei:swiperH        //设置高度
    })
},

  改之前轮播效果

  

 

 改之后轮播图效果

       

综上所述,所改之处只有三点:

1.在  swiper 标签上加属性     style='height:{{Hei}}'  动态的通过图片的高度来决定swiper的高度

2.给轮播图的图片加 属性   mode="widthFix" bindload='imgH'

3.在js文件中:data中加 Hei:""    

  加方法:

imgH:function(e){
    var winWid = wx.getSystemInfoSync().windowWidth;         //获取当前屏幕的宽度
    var imgh=e.detail.height;                //图片高度
    var imgw=e.detail.width;
    var swiperH=winWid*imgh/imgw + "px"          //等比设置swiper的高度。  即 屏幕宽度 / swiper高度 = 图片宽度 / 图片高度    ==》swiper高度 = 屏幕宽度 * 图片高度 / 图片宽度
    this.setData({
        Hei:swiperH        //设置高度
    })
},

 通过以上三步可以是轮播容器显示完整图片

 

posted on 2020-05-25 13:36  RuningY  阅读(5584)  评论(1编辑  收藏  举报

导航