小程序进度条_小程序杂技谈之横向双色进度条
横向双色进度条
先看效果图
data:image/s3,"s3://crabby-images/586b0/586b0d587ceeeb56c2669fa560226e8453e58036" alt="e074ad4514db9d57ece302a8662d4150.png"
小程序自带的进度条不能满足我们想要的效果,所以这里我们决定用view叠加的方式进行动画增长和展示
data:image/s3,"s3://crabby-images/c3ce8/c3ce86295dc2044eefbb4f17d4b4a2b1151d13c6" alt="3c392a98c8d9e56adc691e97114b0eb6.png"
data:image/s3,"s3://crabby-images/1f8d6/1f8d69cdcf4c0f87dd42e765d0e8b0a6d8bc00dc" alt="90453b4d866f730c3c609d58b86219b9.gif"
编写布局
data:image/s3,"s3://crabby-images/d0f3e/d0f3e12069f3cc65468f970f96fab9f8a0d36eea" alt="ae3dc1338870e2da47a4b26d1554b51a.gif"
data:image/s3,"s3://crabby-images/59ba4/59ba474eb13773e6090111f90d0b0ee2492f7a28" alt="bc9d27da60f3bc9111237b78040f3092.png"
data:image/s3,"s3://crabby-images/c5a8c/c5a8cf9b694416ac10de54e89e61c89d35ec1a8a" alt="0dc148a4405fcd42e6e88aec2c00effd.png"
style="margin-bottom:{{index == arrProgress.length-1 ? 46 : 0}}rpx;">
{{item.name}}
= 100}}">
data:image/s3,"s3://crabby-images/a8312/a831294e9f84f741efa3989fae31fc3e6c05b8c8" alt="88dcd3b4aadea2b84fc2f4443eafbc2e.png"
data:image/s3,"s3://crabby-images/c5534/c553471e300cf5365d0e971395d6c53ac9aaddf3" alt="90453b4d866f730c3c609d58b86219b9.gif"
定义样式
data:image/s3,"s3://crabby-images/d2076/d20768b572294bffcd0f23d96f9fed6dbee1b10d" alt="b4557344040877cc6a1e54c6c7640c4d.gif"
data:image/s3,"s3://crabby-images/a5e51/a5e51c1710bf1fff96b27c05d46a1835ae015a2e" alt="58124529c0f2d7dddd47a17defa624be.png"
data:image/s3,"s3://crabby-images/74ab7/74ab703b5bdfbd1c985f2a9c2ac8fd3b3da6284e" alt="baece92bc3bdb8809e42996df115b053.png"
page{
background-color: #f5f5f5;
}
.v_white_border{
margin-top: 200rpx;
width: 680rpx;
margin-left: 35rpx;
border-radius: 20rpx;
background-color: #ffffff;
display: flex;
flex-direction: column;
}
.normal-progress {
position: relative;
height: 95rpx;
width: 600rpx;
margin-left: 33rpx;
}
.normal-progress-name{
height:65rpx;
width: 150rpx;
margin-top: 10rpx;
line-height:65rpx;
font-size:24rpx;
color:#070A0C;
}
.normal-double-progress {
width: 600rpx;
height: 20rpx;
background-color: #F5F5F5;
border-radius: 10rpx;
white-space: nowrap;
}
.normal-progress-1 {
position: relative;
float: left;
height: 20rpx;
width: 0;
background-color: #FF8650;
border-radius: 10rpx;
overflow: hidden;
}
.normal-progress-2 {
position: relative;
height: 20rpx;
width: 0;
background-color: #1C80F1;
}
.wh{
width:100%;
overflow: hidden;
border-radius: 40rpx;
}
.iv_give_like {
position: absolute;
top: 48rpx;
right: -14rpx;
width: 70rpx;
height: 70rpx;
opacity: 0;
}
data:image/s3,"s3://crabby-images/71639/71639fd57b24de5657cd837056a0918588a890bc" alt="4be7d117e7b80d7b851dc9ab6fd4a5b5.png"
data:image/s3,"s3://crabby-images/eda22/eda22e8c7b3f7d54d4df2c0c5e2ee05e89f0b4b8" alt="512612d7d398b0c0e8d7d0d5170d97f0.gif"
编写逻辑
data:image/s3,"s3://crabby-images/7eb7e/7eb7e4e04766e322aeff27183d09af8ebf5577c6" alt="a9b38ffad5a776f0908836950bf4e600.gif"
data:image/s3,"s3://crabby-images/52706/52706702427ff094a3af815c7e06fb60d769f7ae" alt="69f791b96af158685b9cbe156cf8d52c.png"
data:image/s3,"s3://crabby-images/666e2/666e21c8e0fe107c847cfc4e82f2a986bf4d924d" alt="a956c712e0e03b8b1d186525c8b40c8f.png"
我们在.js文件中编写进度条增长动画逻辑
/**
* 页面的初始数据
*/
data: {
arrProgress: [
{
"name": "展示",
"animation1": {},
"animation2": {},
"animation3": {}
},
{
"name": "展示",
"animation1": {},
"animation2": {},
"animation3": {}
},
{
"name": "展示",
"animation1": {},
"animation2": {},
"animation3": {}
},
{
"name": "展示",
"animation1": {},
"animation2": {},
"animation3": {}
}
],
arrPre1 : [50,40,60,100],
arrPre2 : [80,60,70,100]
},
上面初始化了5个进度条并定义了最终的长度
然后在onLoad中进行监听页面加载
/**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
this.progress2Animation(this.data.arrPre1, this.data.arrPre2)
},
这里是主要的逻辑,创建动画createAnimation,并给数组每一个添加动画,计算width的长度并定义增长的时间,最后当到达100时则展示最终动效
progress2Animation: function (arrPre1, arrPre2) {
var arrNew = [];
for (var i = 0; i
var pre1 = arrPre1[i];
var animation1 = wx.createAnimation({
duration: 500
})
var animation2 = wx.createAnimation({
duration: 500
})
var animation3 = wx.createAnimation({
duration: 500
})
if(pre1 > 100){
pre1 = 100
}
animation1.width(pre1 * 6 + 'rpx').step();
animation2.width(pre1 * 6 + 'rpx').step();
animation3.translateX(pre1 * 6 + 'rpx').step();
var oldProgress = this.data.arrProgress[i];
oldProgress.animation1 = animation1.export();
oldProgress.animation2 = animation2.export();
oldProgress.animation3 = animation3.export();
arrNew.push(oldProgress)
}
this.setData({
arrProgress: arrNew,
});
var blockThis = this;
setTimeout(()=>{
blockThis.animate('.iv_give_like', [
{ opacity: 1, scale: [0.9, 0.9] },
{ opacity: 1, scale: [1.2, 1.2] },
{ opacity: 1, scale: [1, 1] },
{ opacity: 1, scale: [1.1, 1.1] },
{ opacity: 1, scale: [1, 1] }
],400, function() {
}.bind(blockThis))
},600)
setTimeout(function () {
arrNew = [];
for (var i = 0; i
var pre2 = arrPre2[i];
var animation1 = wx.createAnimation({
duration: 500
})
var animation3 = wx.createAnimation({
duration: 500
})
if(pre2 > 100){
pre2 = 100
}
animation1.width(pre2 * 6 + 'rpx').step();
animation3.translateX(pre2 * 6 + 'rpx').step();
var oldProgress = blockThis.data.arrProgress[i];
oldProgress.animation1 = animation1.export();
oldProgress.animation3 = animation3.export();
arrNew.push(oldProgress)
}
blockThis.setData({
arrProgress: arrNew
})
}, 500)
},
data:image/s3,"s3://crabby-images/09d47/09d47aa635639c940992a09b4fb1b7b17e03927e" alt="9860fdd390e04c1fb30a7995ef57efd5.png"
data:image/s3,"s3://crabby-images/f7ee2/f7ee2ad7ac87df46442bf5ae43013bc0ccefd236" alt="b3946257105f792bcd179428d9eccbbb.png"
data:image/s3,"s3://crabby-images/512c6/512c6a95ac5606ed5ac09686a63b9679c086c4f2" alt="ab2e77c78f10ab1a9d417b6cce619ad5.png"
data:image/s3,"s3://crabby-images/d1a3e/d1a3ef48b9c78e036df636fe61d9706eaeb25ddf" alt="84e47039fb53e60e114098103a81b461.png"
这样效果就完成了
data:image/s3,"s3://crabby-images/3a40c/3a40c4d6abca340586df3491f33e75ed73932234" alt="c401b434fd5c3d07e7fcb5488b3b801f.png"
data:image/s3,"s3://crabby-images/b87c3/b87c37a24710d1e1b8934e8c12bc357aa6cbede7" alt="764e9a8c220b4cbc01cd27f399015473.png"
data:image/s3,"s3://crabby-images/a6ce3/a6ce3618b709940a53bf490e38ff286f5a92e6d4" alt="9970a98781bb3639a6eb89ca083f1df4.png"
data:image/s3,"s3://crabby-images/e0873/e0873d82fdbb6e4431da0995849a05cfd78b17bd" alt="b0f80dc8c7f84568d860ab697f87c224.png"
data:image/s3,"s3://crabby-images/d6a77/d6a7721295463292f529e4307a406b832bb6191d" alt="1d854328fd23c0f0d722e792c1758965.png"
data:image/s3,"s3://crabby-images/7fa21/7fa2133488072331a6ea1b10e537c919a935b925" alt="cf4fcc3e741f1b441c9b0e073d887c52.png"
万圣节又叫诸圣节,在每年的11月1日,是西方的传统节日;而万圣节前夜的10月31日是这个节日最热闹的时刻。在中文里,常常把万圣节前夜
data:image/s3,"s3://crabby-images/6c545/6c5452e2d46493e5cf96fdada365b16fb06eaf42" alt="7905e71e6bde65a4ea54073f9891da98.png"
data:image/s3,"s3://crabby-images/f1dfe/f1dfe16ecc9aa8dabed10fcaf1d7c101657220bc" alt="63482129c75f369cf3b18095f395d8b8.png"
data:image/s3,"s3://crabby-images/eab69/eab69bb8336127d065f7ec09157b67934211d07d" alt="57bb11c67e70738acfbbf553884e4052.png"
data:image/s3,"s3://crabby-images/f078f/f078ff779533ba50ef0376ce26d672090dec73a4" alt="4092faf0cc08f125d76dfc8e1619680c.png"
data:image/s3,"s3://crabby-images/0944a/0944a30c25449bd85772c6dc367c64f38815129a" alt="dd3f6b35ec578fdfa79ce8c939bab6f4.png"