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

/ 5,985评论 / 24279阅读 / 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. DominicHOr说道:

    mexican pharmaceuticals online: mexican drugstore online – buying prescription drugs in mexico online

  2. RichardMonge说道:

    https://mexicandeliverypharma.online/# mexico pharmacies prescription drugs

  3. Waynetar说道:

    medicine in mexico pharmacies: mexican drugstore online – mexico drug stores pharmacies

  4. DominicHOr说道:

    mexico drug stores pharmacies: best online pharmacies in mexico – purple pharmacy mexico price list

  5. RichardMonge说道:

    https://mexicandeliverypharma.online/# pharmacies in mexico that ship to usa

  6. DominicHOr说道:

    mexican drugstore online: mexico drug stores pharmacies – mexican pharmaceuticals online

  7. Waynetar说道:

    mexican drugstore online: medication from mexico pharmacy – mexican pharmaceuticals online

  8. RichardMonge说道:

    https://mexicandeliverypharma.online/# reputable mexican pharmacies online

  9. Arnoldscava说道:

    mexico drug stores pharmacies mexican drugstore online buying from online mexican pharmacy

  10. Arnoldscava说道:

    mexican drugstore online pharmacies in mexico that ship to usa mexican rx online

  11. Arnoldscava说道:

    reputable mexican pharmacies online purple pharmacy mexico price list mexican online pharmacies prescription drugs

  12. Arnoldscava说道:

    mexican drugstore online mexican border pharmacies shipping to usa mexico pharmacy

  13. MBC说道:

    It is actually one of the few ways on how breaking the house advantage is
    done. The doubling stake means that the Martingale can quickly get very expensive and although you can win with luck (just as you can by playing randomly) it is a very risky way of
    making small profits for potentially high risk.

  14. You’re so interesting! I don’t suppose I have read something like this before. So nice to discover another person with a few unique thoughts on this topic. Seriously.. thank you for starting this up. This web site is something that is required on the internet, someone with a bit of originality.

  15. Hello! I simply want to give you a huge thumbs up for your excellent information you have got here on this post. I will be coming back to your website for more soon.

  16. Klikx说道:

    Can I simply just say what a comfort to uncover someone that truly understands what they are discussing on the net. You definitely know how to bring an issue to light and make it important. More people need to look at this and understand this side of your story. I can’t believe you’re not more popular because you most certainly possess the gift.

  17. RobertLAr说道:

    amoxicillin 500mg over the counter: where can i get amoxicillin 500 mg – amoxacillian without a percription

  18. mp3juices说道:

    You ought to take part in a contest for one of the most useful blogs on the web. I’m going to recommend this website!

  19. helpful site说道:

    Oh my goodness! Incredible article dude! Thank you, However I am encountering difficulties with your RSS. I don’t know why I can’t subscribe to it. Is there anybody getting identical RSS problems? Anyone that knows the solution can you kindly respond? Thanx!

  20. 789b1 com说道:

    There’s definately a great deal to find out about this issue. I really like all the points you made.

  21. 789bet home说道:

    That is a very good tip particularly to those new to the blogosphere. Brief but very accurate information… Many thanks for sharing this one. A must read post.

  22. YTMP3说道:

    After I initially commented I seem to have clicked the -Notify me when new comments are added- checkbox and from now on every time a comment is added I get four emails with the exact same comment. Perhaps there is an easy method you can remove me from that service? Thank you.

  23. Nice post. I learn something totally new and challenging on websites I stumbleupon every day. It will always be useful to read through content from other writers and use a little something from other sites.

  24. I used to be able to find good info from your blog posts.

  25. tubidy mp3说道:

    Excellent post. I’m dealing with a few of these issues as well..

  26. 78win说道:

    I really like reading through an article that will make men and women think. Also, thanks for allowing for me to comment.

  27. 78win说道:

    I needed to thank you for this excellent read!! I definitely loved every little bit of it. I’ve got you bookmarked to check out new stuff you post…

  28. Syble Figgs说道:

    Greetings! Very helpful advice in this particular article! It is the little changes that will make the most significant changes. Many thanks for sharing!

  29. Catherin Toppa说道:

    Very good info. Lucky me I found your website by accident (stumbleupon). I’ve saved as a favorite for later!

  30. Jamesjer说道:

    Paxlovid buy online: paxlovid pharmacy – paxlovid india

  31. Jamesjer说道:

    doxycycline 500mg price: doxycycline capsules 40 mg – doxycycline online uk

  32. Jamesjer说道:

    doxycycline tablet: doxycycline 100mg for sale – doxycycline 100mg online

  33. Jamesjer说道:

    cipro: buy cipro online – ciprofloxacin 500mg buy online

  34. Leanne Varaza说道:

    You need to be a part of a contest for one of the finest sites online. I’m going to highly recommend this website!

  35. Arlen Horkey说道:

    Hi, I do believe this is an excellent blog. I stumbledupon it 😉 I’m going to come back once again since i have book marked it. Money and freedom is the greatest way to change, may you be rich and continue to help other people.

  36. Jamesjer说道:

    cipro ciprofloxacin: ciprofloxacin – buy cipro

  37. Jamesjer说道:

    п»їpaxlovid: Paxlovid over the counter – paxlovid generic

  38. Jamesjer说道:

    buying cheap clomid no prescription: where can i get cheap clomid – order clomid

  39. description说道:

    Oh my goodness! Awesome article dude! Many thanks, However I am going through difficulties with your RSS. I don’t know why I can’t subscribe to it. Is there anybody getting similar RSS problems? Anyone that knows the solution can you kindly respond? Thanks.

  40. Jamesjer说道:

    paxlovid for sale: paxlovid cost without insurance – paxlovid covid

发表回复

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