微信小程序 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 //设置高度 }) },
通过以上三步可以是轮播容器显示完整图片