微信小程序开发怎样实现折叠效果?

来源:品创智慧

开始正题

上方Nav

基本 flex 布局再加个 padding 不需要多讲吧?


提一下,微信小程序里input的placeholder样式是写在 placeholder-style 里或使用 placeholder-class

下方菜单

每个小卡片遵从 flex 布局,设置 width: 50% ,别忘了 flex-wrap: wrap

每个小卡片内部同为 flex 布局并设置垂直居中,想了想还是科普下:

.main-view-item{

display: flex;

justify-content: center;

align-items: center;

width: 50%;

}

flex真他娘的好用

至于里面的图片是从iconfont上拿的,调这几个配色的时间是我布局时间的几十倍....

动画

微信小程序的动画只能用JS,常规手段不可用,来个头脑风暴hack起来

观察每个卡片的折叠方向后,为每个卡片添加初始 rotate 使其反向折叠,我在这里定义了两个Class

.rotateX90{

transform: rotateX(-90deg);

}

.rotateY90{

transform: rotateY(-90deg);

}



20210324



好了这样就看不到卡片了,然后给菜单按钮添加点击事件改变卡片的rotate就Ojbk啦

var duration = 150

var item1 = wx.createAnimation({

duration: duration,

transformOrigin: '0 0 0'

})

item1.rotateX(90).step

this.setData({

item1: item1,

item1Style: 'item1Style'

})

这里注意调整 transformOrigin 来控制折叠方向,对于后面的卡片在 createAnimation 中添加 delay 字段即可(差为 duration 的等差数列)

是不是很简单嗯?

至于菜单的收回,代码和展开差不多,就是反过来而已,不过有些展开的顺序和 transformOrigin 需要注意,这里还是贴一个代码吧:

var duration = 150

var item3 = wx.createAnimation({

duration: duration,

transformOrigin: '100% 100% 0',

delay: duration * 2

})

item1.rotateX(90).step

this.setData({

item3: item3,

item3Style: ''

})


本文关键词:小程序开发,小程序制作,小程序定制,微信小程序,百度小程序,抖音小程序,官网小程序,商城小程序,门户小程序,网络公司,网站营销推广

声明:本网站部分文章转载自网络媒体稿件,是为了传播更多的信息以及学习交流,此类稿件不代表本站观点,本站不承担此类稿件侵权行为的连带责任。故此,如果您发现本网站的内容侵犯了您的版权,请把您的相关内容发至此邮箱【1361323860@qq.com】,我们在确认后,会立即删除,保证您的版权。



阅读987
分享
写评论...