欢迎来到258分享网,纯净的网络源码分享基地!

258资源分享网

全部作品
全部作品
网站源码
微信源码
素材特效
源码插件
视频教程
建站学院
热门搜索: 织梦  农业种植  农业  安全设置  官方
258资源分享 > 建站学院 > 微信开发 > 微信小程序--旋转木马/缩放轮播图效果

推荐下载

HTML5响应式自适应网咯设计

2020-05-12   浏览:740

高端HTML5响应式企业通用网

2020-05-06   浏览:521

html5响应式外贸网站英文版

2020-05-08   浏览:510

HTML5自适应律师工作室类网

2020-04-04   浏览:504

HTML5影视传媒文化公司类网

2020-05-12   浏览:500

微信小程序--旋转木马/缩放轮播图效果

发布时间:2020-10-15  

话不多说先上图.gif

微信小程序--旋转木马/缩放轮播图效果

 

文章涉及技术点 微信小程序原生Swiper控件 Wxss Transform、Transition 轮播条滚动回调控制 微信小程序条件渲染、列表渲染

全部实现代码加起来也就三四十行,大部分还用来写wxml UI代码,所以功能实现起来非常简单。 
首先将问题简单化,能用原生组件实现出我们想要的效果,绝不自己开发Component。原因:我懒+我自己写的也不敢说性能堪比原生组件

先来分析一波gif中我们需要实现效果和哪些效果可以直接修改原生Swiper的属性就能实现的

 

我们需要自己实现的功能

自动滚动+手动拖拽 (原生组件帮我们完成 Property:autoplay) 
面板指示点 (原生组件帮我们完成 Property:indicator-dots) 
左右可以露出非Active状态图的边缘(即Quiet状态, 后文class会以这两个名字定义) (原生组件帮我们完成 Property:previous-margin、next-margin) 
图片滚动到中心位置放大,滚动出去缩小 (我们手写实现,利用技术点中提到的滚动回调+条件渲染。其中滚动回调用 Property:bindchange) 
这样看下来就很清晰了,需要我们实现的只有一个动画放大缩小。再进一步

就能分成两种实现方式:

wxss实现 
js实现

很显然wxss实现代码很少也能达到同样的效果,so~

 

//.wxml

<swiper class='swiperClass' autoplay indicator-color="#a39f99" indicator-active-color="#f49641" indicator-dots interval="2000" duration="1000" previous-margin="30px" next-margin="30px" circular bindchange="bindchange" style='height: {{swiperHeight}}px'>

<block wx:for="{{imgUrls}}" wx:key="{{index}}">

<swiper-item>

<image src=http://www.yiyongtong.com/archives/"{{item}}" class="slide-image {{swiperIndex == index ? 'active' : 'quiet'}}" mode='aspectFill'>

</image>

</swiper-item>

</block>

</swiper>

 

//.wxss

.swiperClass {

margin: 0;

margin-top: 10px;

}

 

.slide-image {

width: 100%;

height: 90%;

border-radius: 10px;

position: relative;

}

 

image.active {

transform: none;

transition: all 0.2s ease-in 0s;

}

 

image.quiet {

transform: scale(0.8333333);

transition: all 0.2s ease-in 0s;

}

 

//.js

data: {

imgUrls: [

'xxx',

'xxx',

'xxx',

'xxx'

],

swiperIndex: 0 //这里不写第一次启动展示的时候会有问题

},

 

bindchange(e) {

this.setData({

swiperIndex: e.detail.current

})

},

上面Swiper控件里面还有设置宽高的属性就随便填几个数测试就好了,不影响主要功能。

注意身体,小心秃顶