<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
本文範例為大家分享了Vue中使用js製作進度條式資料對比動畫的具體程式碼,供大家參考,具體內容如下
實現的效果:(初始化以及瀏覽器resize的時候兩側的條形為向兩側遞增的動畫,其中兩端的數位也是遞增的動畫)
HTML部分:
<div class="no-ivatargo-chart-b"> <div class="investment-ability"> <div class="title"> <span>您的投資能力分析</span> </div> <div class="investment-ability-picture-outer-container"> <div class="investment-ability-picture-container"> <div class="investment-ability-picture-header" ref="allLine"> <span>我</span> <span>平均</span> </div> <div class="investment-ability-picture" v-for="(item, index) in abilityArr" :key="index"> <div class="investment-ability-picture-top"> <div class="investment-left"> <div class="left-icon-outer"> <div class="left-icon-inner"></div> </div> <span>{{item.title}}</span> </div> <div class="investment-right"> <div class="investment-info"> <span class="my-color">{{item.score | scoreFilter}}</span> <div class="all-line"> <div class="my-line" :style="{'width': item.myWidth}"></div> <div class="other-line" :style="{'width': item.averageWidth}"></div> </div> <span class="average-color">{{item.average | scoreFilter}}</span> </div> </div> </div> </div> <div class="investment-ability-picture-footer"> <span>100</span> <span>0</span> <span>100</span> </div> </div> </div> </div> </div>
filters: { scoreFilter (val) { if (!isNaN(val)) { return Number(val) < 10 ? `0${parseInt(val)}` : parseInt(val) } else { return '' } } }
CSS部分:
.no-ivatargo-chart-b { width: 100%; overflow: hidden; display: flex; flex-direction: column; font-size: 14.76px; color: #bfbfbf; background-color: #0f1318; .title { display: flex; align-items: center; font-size: 17.22px; color: #bfbfbf; margin-bottom: 15px; } .investment-ability-picture-header { width: 400px; margin-left: 130px; display: flex; align-items: center; justify-content: space-around; margin-bottom: 10px; color: #fff; } .investment-ability-picture-outer-container { display: flex; justify-content: center; align-items: center; height: calc(100% - 50px); .investment-ability-picture-container { display: flex; flex-direction: column; .investment-ability-picture { display: flex; flex-direction: column; margin-bottom: 10px; .investment-ability-picture-top { display: flex; .investment-left { font-size: 14.76px; color: #bfbfbf; width: 100px; display: flex; align-items: center; .left-icon-outer { width: 14px; height: 14px; background-color: #3fb050; border-radius: 50%; position: relative; margin-right: 5px; .left-icon-inner { position: absolute; width: 5px; height: 5px; top: 50%; left: 50%; transform: translate(-50%, -50%); background-color: #fff; border-radius: 50%; } } } .investment-right { display: flex; align-items: center; justify-content: space-between; .investment-info { display: flex; align-items: center; justify-content: space-between; .all-line { width: 400px; height: 10px; background-color: #57606e; border-radius: 2px; margin-left: 10px; margin-right: 10px; position: relative; .my-line { width: 0; height: 10px; position: absolute; top: 0; right: 200px; background-color: #f5a623; border-top-left-radius: 2px; border-bottom-left-radius: 2px; } .other-line { width: 0; height: 10px; position: absolute; top: 0; left: 200px; background-color: #1890ff; border-top-right-radius: 2px; border-bottom-right-radius: 2px; } } .my-color { width: 20px; color: #f5a623; } .average-color { width: 20px; color: #1890ff; } } } } .investment-ability-picture-bottom { display: flex; flex-direction: column; background-color: #ccc; width: 400px; margin-left: 130px; padding: 5px; color: #000; } } } } .investment-ability-picture-footer { width: 400px; margin-left: 130px; display: flex; align-items: center; justify-content: space-between; color: #fff; } }
JS部分:
1.子元件當中
mounted () { let that = this window.onresize = () => { clearTimeout(that.resizeTimer) that.resizeTimer = setTimeout(() => { that.handleGetAllWidth() }, 1000) } this.$nextTick(() => { clearTimeout(this.resizeTimerB) this.resizeTimerB = setTimeout(() => { this.handleGetAllWidth() }, 200) }) } // methods當中 handleGetAllWidth () { this.$emit('getAllWidth', this.$refs.allLine.offsetWidth) }
2.父元件當中
getAllLineWidth (data) { this.allLineWidth = data this.calculateIvatargo() }, // 給條形圖新增計算寬度,並形成動畫 calculateIvatargo () { this.myTimerArr.forEach((value, index) => { clearInterval(value) }) this.averageTimerArr.forEach((value, index) => { clearInterval(value) }) this.myTimerArr = [] this.averageTimerArr = [] let myVal = [] let averageVal = [] this.myAbilityArr.forEach((value, index) => { myVal[index] = 0 averageVal[index] = 0 this.myTimerArr[index] = setInterval(() => { if (myVal[index] > Number(this.allLineWidth) * Number(value.score) / 200 || !value.score) { clearInterval(this.myTimerArr[index]) value.score ? myVal[index] = Number(this.allLineWidth) * Number(value.score) / 200 : myVal[index] = 0 this.$set(value, 'myWidth', myVal[index] + 'px') this.$set(value, 'myNum', value.score) } else { myVal[index]++ this.$set(value, 'myWidth', myVal[index] + 'px') this.$set(value, 'myNum', myVal[index] / 2) } }, 5) this.averageTimerArr[index] = setInterval(() => { if (averageVal[index] > Number(this.allLineWidth) * Number(value.average) / 200 || !value.average) { clearInterval(this.averageTimerArr[index]) value.average ? averageVal[index] = Number(this.allLineWidth) * Number(value.average) / 200 : averageVal[index] = 0 this.$set(value, 'averageWidth', averageVal[index] + 'px') this.$set(value, 'averageNum', value.average) } else { averageVal[index]++ this.$set(value, 'averageWidth', averageVal[index] + 'px') this.$set(value, 'averageNum', averageVal[index] / 2) } }, 5) }) }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45