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

/ 5,989评论 / 24310阅读 / 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. Matthewnouts说道:

    cost of cheap propecia no prescription: buying generic propecia without dr prescription – buy propecia online

  2. Matthewnouts说道:

    cost propecia without insurance: order generic propecia no prescription – generic propecia

  3. Matthewnouts说道:

    buying propecia no prescription: order cheap propecia prices – buy propecia now

  4. Matthewnouts说道:

    zithromax prescription in canada: zithromax 1000 mg online – zithromax order online uk

  5. LewisToite说道:

    http://nolvadexbestprice.pro/# tamoxifen and grapefruit

  6. Matthewnouts说道:

    zithromax 500mg price: where can i buy zithromax in canada – buy zithromax online fast shipping

  7. Matthewnouts说道:

    prednisone prescription online: no prescription online prednisone – 1 mg prednisone cost

  8. Matthewnouts说道:

    tamoxifen lawsuit: nolvadex online – does tamoxifen cause joint pain

  9. Matthewnouts说道:

    tamoxifen side effects forum: low dose tamoxifen – nolvadex gynecomastia

  10. Matthewnouts说道:

    zithromax 500 mg: zithromax capsules australia – zithromax generic cost

  11. Matthewnouts说道:

    prednisone 250 mg: prednisone brand name india – buying prednisone without prescription

  12. Matthewnouts说道:

    cost of generic zithromax: can you buy zithromax over the counter – zithromax prescription

  13. KevinBlupt说道:

    tamoxifen 20 mg tablet: tamoxifen rash – tamoxifen and bone density

  14. LewisToite说道:

    https://prednisonebestprice.pro/# prednisone 10mg prices

  15. KevinBlupt说道:

    femara vs tamoxifen: tamoxifen depression – tamoxifen vs clomid

  16. Robertperma说道:

    zithromax capsules zithromax 500mg order zithromax without prescription

  17. Robertperma说道:

    where can i buy zithromax capsules zithromax prescription zithromax 1000 mg online

  18. Robertperma说道:

    tamoxifen breast cancer tamoxifen hair loss tamoxifen and weight loss

  19. KevinBlupt说道:

    order propecia for sale: cost generic propecia online – get propecia

  20. LewisToite说道:

    https://prednisonebestprice.pro/# prednisone 10mg buy online

  21. LewisToite说道:

    http://propeciabestprice.pro/# cheap propecia no prescription

  22. Matthewnouts说道:

    cost generic propecia without insurance: cost of generic propecia without dr prescription – cost of cheap propecia pill

  23. Next time I read a blog, Hopefully it won’t fail me as much as this particular one. After all, I know it was my choice to read through, but I really thought you would have something interesting to say. All I hear is a bunch of whining about something that you could possibly fix if you weren’t too busy looking for attention.

  24. KevinBlupt说道:

    what is tamoxifen used for: tamoxifen benefits – tamoxifen 20 mg

  25. Robertperma说道:

    raloxifene vs tamoxifen tamoxifen benefits nolvadex online

  26. Matthewnouts说道:

    buy cytotec over the counter: Abortion pills online – Abortion pills online

  27. Matthewnouts说道:

    zithromax online no prescription: zithromax for sale cheap – zithromax 250

  28. Matthewnouts说道:

    buy cytotec pills: cytotec buy online usa – Cytotec 200mcg price

  29. Robertperma说道:

    cortisol prednisone buying prednisone on line prednisone 10 mg tablets

  30. Robertperma说道:

    tamoxifen for men tamoxifen premenopausal tamoxifen alternatives premenopausal

  31. Robertperma说道:

    cytotec pills buy online cytotec buy online usa purchase cytotec

  32. PatrickHindy说道:

    http://prednisonebestprice.pro/# buy prednisone 10mg online

  33. 大冷 配当说道:

    What do some people say happened to Walt Disney’s body after he died?

  34. Matthewnouts说道:

    get generic propecia without dr prescription: generic propecia pills – cost of propecia without rx

  35. Robertperma说道:

    zithromax prescription online zithromax 500mg price in india zithromax capsules australia

  36. LewisToite说道:

    https://prednisonebestprice.pro/# prednisone for sale in canada

  37. LewisToite说道:

    http://prednisonebestprice.pro/# 50 mg prednisone tablet

  38. LewisToite说道:

    http://zithromaxbestprice.pro/# zithromax online usa no prescription

  39. PatrickHindy说道:

    https://cytotecbestprice.pro/# order cytotec online

  40. Matthewnouts说道:

    cytotec abortion pill: buy misoprostol over the counter – Misoprostol 200 mg buy online

  41. PatrickHindy说道:

    http://zithromaxbestprice.pro/# where can i get zithromax over the counter

  42. PatrickHindy说道:

    http://nolvadexbestprice.pro/# tamoxifen dosage

  43. Matthewnouts说道:

    prednisone nz: prednisone without prescription.net – 25 mg prednisone

  44. Matthewnouts说道:

    cost cheap propecia prices: propecia no prescription – cost propecia online

  45. LewisToite说道:

    https://nolvadexbestprice.pro/# nolvadex half life

  46. Robertperma说道:

    buying cheap propecia prices buy propecia now get propecia no prescription

  47. Robertperma说道:

    Cytotec 200mcg price cytotec online order cytotec online

  48. PatrickHindy说道:

    http://cytotecbestprice.pro/# buy cytotec over the counter

发表回复

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