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

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

    Pin Up Azerbaycan: pin-up kazino – pin-up kazino

  2. Dzięki za to, że skomplikowane tematy SEO stały się bardziej przystępne.

  3. Edwardtes说道:

    pin-up kazino: Pin Up – pin-up kazino

  4. Edwardtes说道:

    Pin Up: Pin-Up Casino – Pin Up Azerbaycan

  5. Dziękuję za poruszenie tematu, który często jest pomijany, jakim jest SEO.

  6. Edwardtes说道:

    Pin up 306 casino: Pin Up Kazino ?Onlayn – Pin Up Azerbaycan

  7. SEO to zdecydowanie nie jest projekt typu zrób to sam. Dzięki za ostrzeżenie!

  8. Edwardtes说道:

    pin-up kazino: pin-up360 – Pin up 306 casino

  9. RobertMob说道:

    https://autolux-azerbaijan.com/# Pin Up Kazino ?Onlayn

  10. Edwardtes说道:

    Pin Up Azerbaycan ?Onlayn Kazino: Pin Up Kazino ?Onlayn – pin-up360

  11. Edwardtes说道:

    Pin-up Giris: Pin-Up Casino – Pin Up

  12. Edwardtes说道:

    Pin up 306 casino: pin-up kazino – ?Onlayn Kazino

  13. Dzięki za praktyczne wskazówki dotyczące znalezienia wykwalifikowanego specjalisty SEO.

  14. Edwardtes说道:

    pin-up kazino: pin-up 141 casino – Pin Up Azerbaycan

  15. audyt seo shoper说道:

    Świetne wskazówki dotyczące znalezienia wiarygodnych usług SEO. Dzięki!

  16. Edwardtes说道:

    Pin-Up Casino: Pin-up Giris – pin-up 141 casino

  17. Edwardtes说道:

    Pin up 306 casino: Pin Up Kazino ?Onlayn – pin-up360

  18. Edwardtes说道:

    Pin up 306 casino: pin-up360 – Pin-Up Casino

  19. home audyt seo说道:

    To była otwierająca oczy lektura na temat ryzyk i procesu SEO.

  20. Edwardtes说道:

    Pin Up Azerbaycan ?Onlayn Kazino: Pin Up Kazino ?Onlayn – Pin Up Azerbaycan

  21. To były bardzo pomocne informacje na temat kroków w SEO.

  22. Very good post. I’m facing many of these issues as well..

  23. Dzięki za jasne i zwięzłe informacje na temat SEO.

  24. scaffolding cost说道:

    This will be a great website, might you be interested in doing an interview about how you developed it? If so e-mail me!

  25. aluminium tower说道:

    It’s a good shame you don’t contain a give money button! I’d definitely give money for this fantastic webpage! That i suppose for the time being i’ll be satisfied bookmarking together with including an individual’s Feed that will my best Msn balance. That i appearance forward that will recent messages and definitely will share the web site utilizing my best Facebook or twitter team: )

  26. tubidy mp3 juice说道:

    I used to be able to find good advice from your blog articles.

  27. Greetings! This is my first visit to your blog! We are a team of volunteers and starting a new project in a community in the same niche. Your blog provided us beneficial information to work on. You have done a marvellous job!

  28. ias scaffolding说道:

    Can I just now say what relief to uncover somebody that in fact knows what theyre discussing on the internet. You certainly learn how to bring an issue to light and produce it important. Workout . must check out this and appreciate this side with the story. I cant believe youre no more well-known simply because you undoubtedly hold the gift.

  29. Good day! I simply would like to give a huge thumbs up for the good data you’ve right here on this post. I shall be coming again to your weblog for extra soon.

  30. Hey, great post you might be interested in some of my Web Design services I offer!

  31. ggc scaffolding说道:

    I delight in, result in I found exactly what I was having a look for. You have ended my four day long hunt! God Bless you man. Have a great day. Bye

  32. Hi! I could have sworn I’ve been to this blog before but after checking through some of the post I realized it’s new to me. Anyhow, I’m definitely glad I found it and I’ll be bookmarking and checking back often!

  33. mobile scaffold说道:

    In the awesome scheme of things you’ll receive an A just for hard work. Exactly where you misplaced me was on your details. As people say, details make or break the argument.. And it couldn’t be more accurate right here. Having said that, permit me reveal to you what exactly did work. The writing can be really convincing which is possibly why I am taking an effort to comment. I do not really make it a regular habit of doing that. Secondly, despite the fact that I can certainly notice the leaps in logic you make, I am not confident of how you seem to connect the details which in turn produce the actual final result. For the moment I will, no doubt yield to your point but wish in the near future you link the facts much better.

  34. pch scaffolding说道:

    I’m impressed, I must say. Really rarely do you encounter a blog that’s both educative and entertaining, and let me tell you, you might have hit the nail on the head. Your concept is outstanding; the issue is something which not enough people are speaking intelligently about. My business is very happy i always stumbled across this within my try to find something relating to this.

  35. gravlock说道:

    I discovered your website internet site on the internet and appearance some of your early posts. Always keep up the very good operate. I simply additional increase your RSS feed to my MSN News Reader. Seeking forward to reading a lot more on your part down the line!…

  36. Pretty! This was a really fantastic post. Thank you for your supplied information Sales Letter Software

  37. tubidy music说道:

    I’m amazed, I have to admit. Seldom do I come across a blog that’s both equally educative and amusing, and let me tell you, you have hit the nail on the head. The problem is an issue that too few people are speaking intelligently about. I’m very happy that I came across this during my hunt for something regarding this.

  38. the best dating websites are those sites which also gives you some freebies and souvenirs~

  39. I would like to thank you for the efforts you have put in writing this website. I’m hoping the same high-grade site post from you in the upcoming as well. Actually your creative writing abilities has encouraged me to get my own website now. Actually the blogging is spreading its wings quickly. Your write up is a good example of it.

发表回复

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