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

/ 6,371评论 / 25436阅读 / 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. Clydewal说道:

    doxycyline online: doxycycline best price – antibiotic doxycycline

  2. Charlescoofs说道:

    http://clomidca.com/# prednisone 20 mg prices

  3. Clydewal说道:

    buy cheap zithromax online: amoxicillinca – zithromax capsules

  4. Billyziz说道:

    doxycycline 100mg tablet price doxycycline azithromycinca doxycycline tablets australia

  5. Clydewal说道:

    can i buy zithromax over the counter in canada: buy zithromax amoxicillinca – zithromax online usa no prescription

  6. Billyziz说道:

    buy zithromax 500mg online buy zithromax online buy cheap zithromax online

  7. Clydewal说道:

    amoxicillin 500mg over the counter: amoxil – amoxicillin 500mg

  8. Billyziz说道:

    100 mg prednisone daily prednisone prednisone buy without prescription

  9. Clydewal说道:

    where can i order doxycycline: doxycycline – buy doxycycline online canada

  10. Billyziz说道:

    prednisone 20 tablet prednisone buy prednisone canada

  11. Clydewal说道:

    prednisone uk over the counter: prednisone – prednisone 40 mg tablet

  12. Billyziz说道:

    amoxicillin 500 mg tablet price cheapest amoxicillin order amoxicillin online no prescription

  13. Clydewal说道:

    zithromax 1000 mg pills: zithromax – zithromax z-pak price without insurance

  14. Billyziz说道:

    prednisone pharmacy clomidca.com prednisone 50

  15. Clydewal说道:

    can i buy cheap clomid tablets: Clomiphene – can i buy clomid without insurance

  16. Carlosnatry说道:

    can you buy doxycycline over the counter canada: azithromycinca – cheapest doxycycline without prescrtiption

  17. Billyziz说道:

    where to get generic clomid without prescription Clomiphene order generic clomid pills

  18. tubidy说道:

    Greetings! Very useful advice within this post! It is the little changes that will make the largest changes. Many thanks for sharing!

  19. Billyziz说道:

    online doxycycline azithromycinca.shop doxycycline 100 mg cap

  20. Billyziz说道:

    where can i buy cheap clomid price best price how to get generic clomid price

  21. Clydewal说道:

    where to get cheap clomid prices: cheap fertility drug – where can i get cheap clomid pill

  22. Carlosnatry说道:

    zithromax prescription: cheapest Azithromycin – zithromax pill

  23. Billyziz说道:

    doxycycline 10mg tablets doxycycline azithromycinca doxycycline 40 mg india

  24. Clydewal说道:

    zithromax 500 mg lowest price drugstore online: zithromax – can i buy zithromax online

  25. Billyziz说道:

    prednisone 4mg tab clomidca prednisone 20 mg purchase

  26. Clydewal说道:

    doxycycline canadian online pharmacy: doxycycline – doxycycline order online canada

  27. Billyziz说道:

    amoxicillin script amoxil doxycyclineca amoxicillin 500mg capsules antibiotic

  28. Clydewal说道:

    where can i purchase zithromax online: Azithromycin best price – zithromax over the counter canada

  29. Billyziz说道:

    amoxicillin 875 mg tablet amoxil doxycyclineca amoxicillin medicine over the counter

  30. Clydewal说道:

    where can i buy prednisone: Deltasone – over the counter prednisone cream

  31. Charlescoofs说道:

    http://azithromycinca.com/# doxycycline 10mg tablets

  32. Billyziz说道:

    average cost of prednisone 20 mg clomidca.com 100 mg prednisone daily

  33. Clydewal说道:

    order amoxicillin online no prescription: amoxil – generic amoxicillin cost

  34. Carlosnatry说道:

    azithromycin amoxicillin: amoxil doxycyclineca – canadian pharmacy amoxicillin

  35. mp3juice说道:

    This is a topic which is close to my heart… Many thanks! Exactly where are your contact details though?

  36. Fantastic site. Lots of useful information here. I am sending it to a few pals ans also sharing in delicious. And certainly, thank you to your effort!

  37. Lady Gaga is looking to get to be reincarnated as a ‘mean and ferocious version to do with herself in a future lifetime.

  38. Very well-done blog. I especially appreciate content that has to do with health and fitness, so it’s refreshing to me to see what you have here. Keep it up! facial exercises

  39. It’s perfect time to make some plans for the future and it’s time to be happy. I’ve read this post and if I could I desire to suggest you few interesting things or tips. Maybe you could write next articles referring to this article. I want to read more things about it!

  40. Amaze! Thank you! I constantly wished to produce in my internet site a thing like that. Can I take element of the publish to my blog?

  41. I just additional this particular feed to be able to my book marks. I need to say, I seriously take pleasure in reading your own sites. Keep it up!

  42. Audio began playing any time I opened up this blog, so frustrating!

  43. The the next time I read a blog, I’m hoping who’s doesnt disappoint me about that one. I mean, I know it was my replacement for read, but I really thought youd have some thing fascinating to talk about. All I hear is really a number of whining about something you could fix when you werent too busy searching for attention.

  44. I was really lucky to find this internet site on bing, just what I was searching for : D likewise saved to favorites .

  45. Well worded post will be sharing this with my readers this evening

  46. Additionally, it doesn’t matter how extremely you should be complete with treating a very platform, gradually you’ll discover an instance the places you should want to do a number instruct care; and as a consequence influenced by your real age but also bodybuilding, therfore the inches of one’s caravan it could be a awfully excessive pastime. motor movers

  47. Ha ha… I was just surfing around and took a look at these feedback. I can’t believe that there’s still this much interest. Thanks for posting about this.

  48. Thanks. I really like your site. Great points you make in your post.

  49. Just wanted to give you a shout from the valley of the sun, great information. Much appreciated.

发表回复

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