文章目录
- 一、效果图
- 二、使用步骤
- 1.公共的进度条组件
- 2.使用
- 总结
一、效果图
二、使用步骤
1.公共的进度条组件
我这里命名的progressBar.vue, 你们使用的时候直接复制粘贴到自己的项目里面即可。
文件中代码如下(示例):
<template>
<div>
<div style="width: 100%;height: 100%">
<div v-for="(item, index) in showList" :key="index + item.value" class="item">
<div :class="index < 3 && page == 1 ? ('itemIcon' + (index + 1)) : 'itemIcon'">{{ index + 1 }}</div>
<div class="itemTitle">{{ item.name }}</div>
<div class="itemValue">{{ item.value }}{{unit}}</div>
<div class="itemBar">
<div :class="index < 2 && page == 1 ? ('innerBar' + (index + 1)) : 'innerBar'" :style="'width:' + (item.value / maxValue * 100).toFixed(2) + '%;'"></div>
</div>
</div>
<div class="pager-content">
<div v-for="pageNum in totalPage" :class="pageNum == page ? 'selected' : ''" @click="page = pageNum"></div>
</div>
</div>
</div>
</template>
<script>
export default {
name: "progressBar",
props: {
dataList:{
type: Array,
default:[
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
],
},
unit:{
type: String,
default:'%',
}
},
data () {
return {
page: 1,
limit: 7,
}
},
computed: {
showList () {
return this.dataList.slice(((this.page - 1) * this.limit), (this.page * this.limit))
},
totalPage () {
const length = this.dataList.length
let value = Math.floor(length / this.limit)
if (length % this.limit !== 0) value++
return value
},
maxValue(){
let maxNum = 0
let list = this.dataList.map(i => i.value)
maxNum = Math.max(...list)
return maxNum
}
},
}
</script>
<style scoped lang="less">
.item{
position: relative;
margin-top: 30px;
width: 100%;
height: 45px;
.itemIcon1{
position: absolute;
background: url("");
width: 42px;
height: 44px;
font-family: DINPro-Bold;
font-size: 16px;
font-weight: normal;
font-stretch: normal;
line-height: 44px;
letter-spacing: 0px;
color: #ffffff;
text-align: center;
}
.itemIcon2{
position: absolute;
background: url("");
width: 42px;
height: 44px;
font-family: DINPro-Bold;
font-size: 16px;
font-weight: normal;
font-stretch: normal;
line-height: 44px;
letter-spacing: 0px;
color: #ffffff;
text-align: center;
}
.itemIcon3{
position: absolute;
background: url("");
width: 42px;
height: 44px;
font-family: DINPro-Bold;
font-size: 16px;
font-weight: normal;
font-stretch: normal;
line-height: 44px;
letter-spacing: 0px;
color: #ffffff;
text-align: center;
}
.itemIcon{
position: absolute;
width: 42px;
height: 44px;
font-family: DINPro-Bold;
font-size: 16px;
font-weight: normal;
font-stretch: normal;
line-height: 44px;
letter-spacing: 0px;
color: #ffffff;
text-align: center;
visibility: hidden;
}
.itemTitle{
position: absolute;
left: 50px;
font-family: SourceHanSansCN-Regular;
font-size: 16px;
font-weight: normal;
font-stretch: normal;
//line-height: 47px;
letter-spacing: 0px;
color: #7fbfff;
}
.itemValue{
position: absolute;
right: 20px;
font-family: SourceHanSansCN-Regular;
font-size: 16px;
font-weight: normal;
font-stretch: normal;
//line-height: 47px;
letter-spacing: 0px;
color: #ffffff;
}
.itemBar{
position: absolute;
left: 50px;
top: 25px;
width: calc(100% - 70px);
height: 20px;
background-color: #031632;
border-radius: 9px;
border: solid 1px #0234a7;
.innerBar1{
position: relative;
margin-left: 2px;
margin-top: 2px;
height: 14px;
background-image: linear-gradient(180deg,
#ffe62c 0%,
#ffa202 100%),
linear-gradient(
#eeeeee,
#eeeeee);
background-blend-mode: normal,
normal;
border-radius: 7px;
border: solid 1px #03297f;
animation: lToR 2s;
-moz-animation: lToR 2s;
-webkit-animation: lToR 2s;
-o-animation: lToR 2s;
}
.innerBar2{
position: relative;
margin-left: 2px;
margin-top: 2px;
height: 14px;
background-image: linear-gradient(180deg,
#2be9b6 0%,
#049b68 100%),
linear-gradient(
#eeeeee,
#eeeeee);
background-blend-mode: normal,
normal;
border-radius: 7px;
border: solid 1px #03297f;
animation: lToR 2s;
-moz-animation: lToR 2s;
-webkit-animation: lToR 2s;
-o-animation: lToR 2s;
}
.innerBar{
position: relative;
margin-left: 2px;
margin-top: 2px;
height: 14px;
background-image: linear-gradient(180deg,
#2cd0ff 0%,
#0084ff 100%),
linear-gradient(
#eeeeee,
#eeeeee);
background-blend-mode: normal,
normal;
border-radius: 7px;
border: solid 1px #03297f;
animation: lToR 2s;
-moz-animation: lToR 2s;
-webkit-animation: lToR 2s;
-o-animation: lToR 2s;
}
}
}
.pager-content{
position: absolute;
bottom: 30px;
height: 20px;
display: flex;
justify-content: space-evenly;
flex-flow: row nowrap;
background: rgba(0,0,0,0.3);
padding-top: 4px;
border-radius: 10px;
width: 85%;
width: 250px;
left: calc(50% - 125px);
}
.pager-content>div{
width: 12px;
height: 12px;
cursor: pointer;
background: url("") no-repeat center center;
}
.pager-content .selected{
background: url("") no-repeat center center !important;
}
@keyframes lToR
{
from {width: 0px;}
}
@-moz-keyframes lToR /* Firefox */
{
from {width: 0px;}
}
@-webkit-keyframes lToR /* Safari and Chrome */
{
from {width: 0px;}
}
@-o-keyframes lToR /* Opera */
{
from {width: 0px;}
}
</style>
2.使用
在另外一个文件中要使用进度条组件,代码如下(示例):
<template>
<div class="part3_2">
<progressBar class="part_content" :dataList="dataList" :unit="'%'"></progressBar>
</div>
</template>
<script>
import progressBar from "../../../components/progressBar.vue";
export default {
name: 'part3_2', // vue名称
components:{progressBar},
data () {
return {
dataList: [],
}
},
mounted() {
this.init()
},
methods: {
//初始值
async init(){
this.dataList = [
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), },
{ name: '旅游行业', value: (Math.random() * 100).toFixed(1), }
]
this.dataList.sort((a,b) => {
return b.value - a.value
})
},
}
}
</script>
<style scoped lang="less">
.part3_2{
position: absolute;
top: 230px;
left: 60px;
width: 31%;
height: calc(100% - 250px);
.part_content {
position: absolute;
top: 30px;
width: 100%;
height: calc(100% - 30px);
overflow: auto;
}
}
</style>
总结
以上就是我今天分享的内容,觉得有用的读者可以动动小手点一个小赞。