プロジェクトの途中で、js の requestAnimationFrame メソッドを使用してプログレスバーを実装し始めましたが、データ量が多い場合にパフォーマンスに大きな影響を与えるため、 css を使用して実装し、最適化します。
最初にコードを投稿します:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style type="text/css"> *{margin: 0;padding: 0} .box{width: 100px;height: 10px;border-radius: 10px;background: #999;margin: 100px auto;border: 1px solid #ff6780;} .child{position: relative;height:100%;border-radius:inherit;} .process-animate{background: #ff6780;position: absolute;left: 0;top: 0;bottom: 0;border-radius:inherit; animation: process 1s linear forwards ; } @keyframes process { 0%{ left:0;right:100%; } 20%{ right:80% } 40%{ right:60%; } 60%{right:40%;} 80%{right:20%;} 100%{right:0;} } </style> </head> <body> <p class="box"> <p class="child" style="width:50%"> // child的百分比就是进度条的占比效果 <p class="process-animate"></p> </p> </p> </body> </html>
効果の画像 (コードをコピーして動的な効果を確認します):
通常の状況では、バックグラウンド データに基づいて計算されるため、動的に渡されます。vue コードは
プログレス バー サブコンポーネント (progress.vue) の下に掲載されます:
<template> <p class="process-wrapper" :class="{'addGray':addGray}"> <p class="process-child" ref="processChild"> <p class="process-animate" :class="{'addGray':addGray}"></p> </p> </p> </template> <script> export default { props: { addGray: { //置灰 type: Boolean, default: false }, progressWidth: { //进度条百分比 type: Number, default: 0 } }, mounted() { this.$nextTick(() => { console.log(this.addGray, "addGray---"); this.$refs.processChild.style.width = this.progressWidth + "%"; //动态改变进度条 // this.$refs.processChild.style.width = 90 + "%"; 测试效果 }); } }; </script> <style lang="scss" scoped> .process-wrapper { width: 1.98rem; height: 0.13rem; margin: 0.12rem 0 0.1rem 0; border-radius: 0.1rem; background: #fff; border: 0.01rem solid #ff6780; &.addGray { background: #999; border: 0.01rem solid #999; } .process-child { position: relative; height: 100%; // width: 100%; //这个width就是动态变化。通过js改变 border-radius: inherit; .process-animate { background: #ff6780; position: absolute; left: 0; top: 0; bottom: 0; border-radius: inherit; animation: process 1s linear forwards; &.addGray { background: #999 !important; // border: 0.01rem solid #999; } } } } @keyframes process { 0% { left: 0; right: 100%; } 20% { right: 80%; } 40% { right: 60%; } 60% { right: 40%; } 80% { right: 20%; } 100% { right: 0; } } </style>
親コンポーネントの呼び出し:
<!-- 进度条 --> <Progress :addGray="inactive" :progressWidth="progressWidth"></Progress>
実際の効果を確認してください:
推奨チュートリアル: 「CSS チュートリアル 」
以上がCSS3でプログレスバー効果を実現する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。