当前位置: 首页 > news >正文

免费高清图片素材网站推荐建设部住房城乡建设厅网站

免费高清图片素材网站推荐,建设部住房城乡建设厅网站,做照片书网站,关于建设网站的图片在微信小程序中,需要实现展示5个,横向层叠的轮播图效果,轮播图由中间到2侧的依次缩小.如下图 使用原生小程序进行开发,没有使用Skyline模式,所以layout-type配置项也无效。所以基于swiper组件进行调整。 主要思路就是设置不同的样式&#xff…

在微信小程序中,需要实现展示5个,横向层叠的轮播图效果,轮播图由中间到2侧的依次缩小.如下图效果图
使用原生小程序进行开发,没有使用Skyline模式,所以layout-type配置项也无效。所以基于swiper组件进行调整。
主要思路就是设置不同的样式,根据当前激活的项,来动态切换样式。
需要注意的是,下文激活的项指的是中间最大的一项,而不是swiper激活的最左侧的一项

1. swiper-item

由于有层叠效果,所以要给不同的swiper-item元素添加上不同的zindex层级。而swiper-item元素自带绝对定位。
在这里插入图片描述
根据层叠数量决定需要加几个层级。当有5个时,只要给激活的中间项加上最高的层级,左右2侧加上低一层级。

2. item

不同层级的swiper-item中的item对应有不同的样式,根据所在的不同层级,需要给对应的item添加上具体的效果样式。
此效果需要给不同的item添加缩放和左右偏移样式

3.动态切换

在轮播图的切换中,需要给各个swiper-item动态切换样式。
我实现的方式是在swiper的bindchange方法中改变激活项的序号,编写wxs方法,将当前激活序号和此项序号传入方法进行判断,返回不同的类,wxml动态渲染不同的类。
同时轮播图一般需要循环无限滚动,所以也需要加上轮播图项的个数。

<swiper class="swiperedu" display-multiple-items="5"  circular="{{true}}" bindchange="swiperChange" autoplay="{{true}}"><swiper-item wx:for="{{list}}" wx:key="{{item}}" class="{{transform.classindex(index,nowIdx,listlen)}}"><view class='{{transform.classtype(index,nowIdx,listlen)}}'></view></swiper-item>
</swiper>

classindex方法动态的判断swiper-item的层级,classtype方法动态判断item的样式。

// 判断样式
var classtype = function(index,curindex,length){var indexnum = parseInt(index),curindexnum = parseInt(curindex);var cha = Math.abs(indexnum-curindexnum);//激活项是list最后一项if(curindex ==length-1){// 首尾衔接,第一项在最后一项右边if(index==0){return '激活项右边样式类';}}//激活项是list最后一项else if(curindex==0){// 首尾衔接,最后一项在第一项在左边if(index==length-1){return '激活项右左边样式类';}}//激活项if(cha==0){return '激活项样式'}//激活项右侧else if(indexnum-curindexnum==1){return '激活项右边样式类';}//激活项左侧else if(indexnum-curindexnum==-1){return '激活项左边样式类';}else {return '普通样式'}
}
// 判断层级
var classindex = function(index,curindex,length){var indexnum = parseInt(index),curindexnum = parseInt(curindex);var cha = Math.abs(indexnum-curindexnum);//激活swipet-item是list最后一项if(curindex ==length-1){// 首尾衔接,第一swiper-item在最后一个右边if(index==0){return 'zindex2';}}//激活swiper-item是list最后一项else if(curindex==0){// 首尾衔接,最后swiper-item在第一个左边if(index==length-1){return 'zindex2';}}//激活项,层级最高if(cha==0){return 'zindex3'}//左右两侧,层级第2else if(cha==1){return 'zindex2';}//普通不加层级else {return ''}
}

轮播图循环变化时,要计算%的序号

    swiperChange(e) {this.setData({nowIdx: (e.detail.current + 2) % this.data.list.length,})},

e.detail.current是轮播图的currentIndex,指的是swiper最左侧的swiper,由于效果中激活项是坐起第3项,所以激活的index需要+2;

总结

这个效果的变化是由swiper自动切换,触发bindchange方法推动的。没有显式的声明swiper的current。
对于提供给用户切换箭头方法的层叠轮播图,需要声明swiper的current属性,用户的切换和current切换的事件会相互冲突,那个效果有时间再写吧

http://www.yayakq.cn/news/199751/

相关文章:

  • 注册网站名字网站头图设计
  • 专业网站设计企业互联网行业前沿资讯
  • 做视频的网站wordpress主题评论制作
  • 个人网站备案方法做网站程序
  • 网站做点线表格网络营销措施有哪些
  • 张家港手机网站制作大连网站建设1000元
  • 做网站需要的合同建行网站登录不了
  • 网站设计流程步骤广州市天河区
  • gta5房产网站正在建设网站建设包括哪些内容
  • 网站开发价格预算网站开发所需的技术
  • 连云港建设工程质量监督站网站wordpress-5.0升级未被安装
  • 网站做数据分析的意义项目计划书怎么写
  • 怎样建设网站空间怎么申请app软件
  • 动漫网站建设目的建筑工程招标网
  • 门户网站开发维护合同瀑布网站模板
  • wordpress建淘宝客网站教程开通微信公众号流程需要什么
  • 有什么网站建设比较好的公司定制类电商平台
  • 系网站的开发和建设毕业设计网页制作网站知识
  • paypal网站做外贸个人博客网页制作图片
  • 公司网站制作公司排名网站美工和平面设计师
  • php WordPress开发seo推广的特点有
  • 门户网站建设哪专业广州seo优化代理
  • 手表常用网站下载ppt模板免费
  • 有前景的长沙企业网站建设网上书店网网站建设
  • 哪个网站教人做美食小吃培训机构排名前十
  • 机械做网站好处外贸建站新闻资讯
  • 物联网网站设计网站推广公司
  • 做网站用vs还是dw重庆网领网站建设公司
  • 商务网站平台建设预算昆明官网seo费用
  • 网站和软件建站百度站长工具验证