[vue3]audio音乐进度条(二)跟随播放进度

/ 7,846评论 / 30329阅读 / 2点赞

上一期我们介绍了外观设计,这把我们聊聊让进度条跟随播放进度走

预期效果


准备


实现

<div id="root_div" class="cmusic_displayFlex_class" style="height:150px;justify-content:space-between;align-items: center;">
    <!-- 音频 -->
    <audio id="cmusic_audio" ref="cmusic_audio" controls muted
        @timeupdate="audio_lengthChange()" :src="url_audio">
    </audio>

    <span id="cmusic_control_span_progressBar">
        <div class="cmusic_displayFlex_class cmusic_control_progress_div" style="flex-direction: row;">
            <span id="cmusic_control_span_loadProgress" :style="cmusic_control_loadProgress_style"></span>
            <span id="cmusic_control_span_progress" :style="cmusic_control_progress_style"></span>
        </div>
    </span>
<div>
<style>
/*外框*/
#cmusic_control_span_progressBar{
    border-radius: 50px;
    height: 20px;
    width: 100%;
    display: inline-flex;
    align-items: center;
    position: relative;
    background: transparent;
    box-shadow: inset 2px 2px 4px #bcc5d6,
        inset -2px -2px 5px #feffff;
    border: 2px solid #d0f4ff;
    justify-content: center;
    transition: all 0.8s ease;
}
/*布局类*/
.cmusic_displayFlex_class {
    width: 100%;
    display: flex;
    flex-direction: column;
    margin-left: auto;
    margin-right: auto;
}
.cmusic_control_progress_div {
    position:absolute;
    width:94% !important;
    height:100%;
    align-items: center;
}
/*进度条*/
#cmusic_control_span_progress,
#cmusic_control_span_loadProgress{
    background: linear-gradient(90deg, #c4f4fe, #66ccff);
    border-radius: 50px;
    position: absolute;
    width:100%;
    height: 60%;
    pointer-events: none;
    transition: width 0.5s ease;
    box-shadow: 2px 2px 10px #ccd3ff,
    -2px -2px 10px #ccd3ff;
}
/*加载进度条*/
#cmusic_control_span_loadProgress {
    background: linear-gradient(90deg, #abecd6, #fff9d2);
}
</style>
<!-- 引入vue -->
<script src="https://unpkg.com/vue@3.2.33"></script>
<script>
const { createApp } = Vue

var cmusic_json = {
    //数据
    data() {
        return {
            url_audio:"https://blog.coolight.cool/wp-content/uploads/2022/05/大喜_洛天依.m4a",
            cmusic_control_loadProgress_style:"width:80%",
            cmusic_control_progress_style:"width:50%"
        }
    },
    //函数
    methods:{
        //监听播放时长,修改进度条长度
        audio_lengthChange:function(){
            let caudio = this.$refs.cmusic_audio;
            //duration是音频总时长
            //如果音频元数据加载完成,才能获得其总时长,后续才能进行计算
            if (!isNaN(caudio.duration)){
                this.cmusic_control_progress_style = "width:" + (parseInt(caudio.currentTime / caudio.duration * 100)).toString() + "%;";
            }else{
                this.cmusic_control_progress_style = "width:0%;";
            }
        }
    }
};

var cmusic_app = Vue.createApp(cmusic_json);
var cmusic_vue = cmusic_app.mount("#root_div");
</script>
  1. Jeffreyblunk说道:

    top 10 online pharmacy in india: India pharmacy delivery – top 10 online pharmacy in india

  2. MatthewEnupe说道:

    mexican online pharmacies prescription drugs Online Mexican pharmacy buying from online mexican pharmacy

  3. Jeffreyblunk说道:

    best online pharmacy india: india pharmi – buy prescription drugs from india

  4. WillardTip说道:

    http://canadianpharmi.com/# buying pills online

  5. StephenPsync说道:

    https://mexicanpharmi.com/# mexican online pharmacies prescription drugs

  6. MatthewEnupe说道:

    mexico pharmacies prescription drugs Mexican pharmacies that ship to the United States pharmacies in mexico that ship to usa

  7. Ernestriz说道:

    buy prescription drugs from india: India pharmacy delivery – india online pharmacy

  8. StephenPsync说道:

    http://mexicanpharmi.com/# mexican drugstore online

  9. WillardTip说道:

    http://indiapharmi.com/# top online pharmacy india

  10. StephenPsync说道:

    http://mexicanpharmi.com/# mexican pharmaceuticals online

  11. Jeffreyblunk说道:

    buying prescription drugs in mexico: Cheapest online pharmacy – buying prescription drugs in mexico online

  12. MatthewEnupe说道:

    pain medications without a prescription Best Canadian online pharmacy buying ed pills online

  13. Jeffreyblunk说道:

    mexican pharmaceuticals online: mexicanpharmi – reputable mexican pharmacies online

  14. WillardTip说道:

    https://indiapharmi.com/# reputable indian online pharmacy

  15. JustinEurok说道:

    http://slottr.top/# az parayla cok kazandiran slot oyunlar?

  16. TravisCange说道:

    en kazancl? slot oyunlar?: slot oyunlar? puf noktalar? – az parayla cok kazandiran slot oyunlar?

  17. So, I have to agree with the authorities, that opening books can cause lots of harm or at finest much wasted time.

  18. Robertfer说道:

    discount casД±no bahis siteleei en iyi casino oyunlarД±

  19. JustinEurok说道:

    https://slottr.top/# az parayla cok kazandiran slot oyunlar?

  20. Josephjer说道:

    casinonaxi: deneme bonusu veren bet siteleri – yasal Еџans oyunlarД± siteleri

  21. Josephjer说道:

    bahis siteleri isimleri: bonus veren bahis siteleri casino – betnoo

  22. Robertfer说道:

    en cok kazand?ran slot oyunlar? en cok kazand?ran slot oyunlar? slot oyunlar? puf noktalar?

  23. Edwardidomo说道:

    https://slottr.top/# az parayla cok kazandiran slot oyunlar?

  24. The U.S. Army used Ross’s Landing as the positioning of certainly one of three large internment camps, or “emigration depots”, where Native People had been held earlier than the journey on the Path of Tears.

  25. K and Davichi. And the instruments for connecting keep getting higher, including the current improvements in social media.

  26. The fourth and last recreation of the rapid tie-break was a victory for Ding Liren, resulting in him winning the world championship.

  27. オダセン聖说道:

    Every time I hear it now, that feeling of comfort washes over me.

  28. JustinEurok说道:

    https://pinup2025.com/# пин ап вход

  29. Robertfer说道:

    en bГјyГјk bahis siteleri son bahis gГјncel giriЕџ bet oyun siteleri

  30. JustinEurok说道:

    http://casinositeleri2025.pro/# en iyi bahis uygulamasД±

  31. Edwardidomo说道:

    https://slottr.top/# en cok kazand?ran slot oyunlar?

  32. Josephjer说道:

    пин ап вход: пин ап казино – пинап казино

  33. Robertfer说道:

    slot oyunlar? slot siteleri en cok kazand?ran slot oyunlar?

  34. JustinEurok说道:

    http://slottr.top/# slot oyunlar? puf noktalar?

  35. Tubidy说道:

    bookmarked!!, I really like your site.

  36. JustinEurok说道:

    http://slottr.top/# slot siteleri

  37. Тут можно сейф ценасейф

  38. Robertfer说道:

    discount casıno kaçak bahis siteleri bonus veren siteler bahis

  39. TravisCange说道:

    pinup 2025: pinup 2025 – пин ап зеркало

  40. JustinEurok说道:

    https://casinositeleri2025.pro/# hangi bahis siteleri bonus veriyor?

  41. Josephjer说道:

    slot tr online: slot oyunlar? – en kazancl? slot oyunlar?

  42. Josephjer说道:

    en cok kazand?ran slot oyunlar?: az parayla cok kazandiran slot oyunlar? – az parayla cok kazandiran slot oyunlar?

  43. Robertfer说道:

    пин ап пин ап вход pinup 2025

  44. Edwardidomo说道:

    https://pinup2025.com/# пинап казино

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注