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

/ 6,434评论 / 25643阅读 / 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. xxx说道:

    lesbian porn

  2. Hi there! This post could not be written much better! Going through this article reminds me of my previous roommate! He continually kept talking about this. I’ll forward this article to him. Fairly certain he will have a great read. Thanks for sharing!

  3. mp3juices说道:

    This is a topic that is close to my heart… Many thanks! Exactly where can I find the contact details for questions?

  4. You are so awesome! I don’t suppose I’ve read something like this before. So good to discover somebody with a few genuine thoughts on this topic. Seriously.. many thanks for starting this up. This web site is something that is required on the web, someone with a bit of originality.

  5. tubidy music说道:

    Very good article. I will be facing a few of these issues as well..

  6. We still cannot quite believe Possible come to be those types of staring at the important points located on your blog post. His dad and so i are sincerely thankful with regards to your generosity and then for giving me possibility pursue our chosen profession path. Wanted info I purchased belonging to the web-site.

  7. porn说道:

    Very good blog post. I absolutely appreciate this site. Thanks!

  8. There are certainly a couple more details to take into consideration, but thanks for sharing this info.

  9. rat problem说道:

    i’m fond of using vending machines because you can instantly get a drink or a snack,

  10. When I originally commented I clicked the -Notify me when new comments are added- checkbox now whenever a comment is added I receive four emails sticking with the same comment. Possibly there is any way you can get rid of me from that service? Thanks!

  11. Thanks a lot for this tips provided! I seemed to be looking for this kind of article for a number of years, yet I was not able to see a trusted source.

  12. GALILEO FX说道:

    I wanted to thank you for this excellent read!! I certainly loved every bit of it. I’ve got you book marked to check out new stuff you post…

  13. In this first movie, Spock and Kirk aside, perhaps, they seem to be pale imitations.

  14. An impressive share! I’ve just forwarded this onto a co-worker who was conducting a little homework on this. And he in fact bought me lunch because I found it for him… lol. So allow me to reword this…. Thanks for the meal!! But yeah, thanks for spending the time to discuss this subject here on your internet site.

  15. ngentot说道:

    This website certainly has all of the information I wanted about this subject and didn’t know who to ask.

  16. memek说道:

    Pretty! This was an incredibly wonderful post. Thank you for providing this info.

  17. quotes说道:

    This site really has all the info I needed concerning this subject and didn’t know who to ask.

  18. slot说道:

    homosexual porn

  19. Zer说道:

    There’s not much to do here other than blow and throw the dice and hope your numbers come up. The house edge ranges from 1.4 to 5%, depending on the craps game you’re playing. Beginners should focus on the Don’t Pass Don’t Come bets, where players lose on a two-dice Don’t Come bet if the throw is 7 or 11 but win if the roll is 2 or 3. Throw any other number and that’s the Don’t Come point. Casino War is one of the least-played casino games. In this very fast-paced game, punters either wager on the game ending in a tie or on which card will be higher between the player and the banker. Casino war is played with a standard 52-card deck and requires no skill to play. The payout for a tie is usually a high 10:1, but this may vary depending on the deck used for the game. The banker and player hands each have 46.3% chance of winning. The house edge can vary depending on the number of decks in play and the rules used by the casino.
    http://forums.wolflair.com/member.php?u=114120
    Anyway, you can always check PROVEN bonuses with detailed video-instruction on our YouTube channel – How to get Online Casino no deposit Bonus. About Author: Victoria is a dedicated content writer, working in the gambling industry since 2015. Her main duties are to look for new and exciting promotions that are not available anywhere else and bring them to you. Victoria also tests bonuses and is in direct contact with casino managers. Her passion for supplying our readers with the latest and exclusive bonuses has no borders, this is why spicycasinos is the best hub for finding no deposit bonuses. CasinoGap.org is part of Gap Media LTD, the company based at 24 Ridgeway Rd, Isleworth, TW7 5LA, United Kingdom GemBet Casino’s Free Credit No Deposit Bonus offers a generous MYR 168 to new players without any initial deposit required. This bonus is a great way to start exploring a range of games from select providers without risking your own funds.

  20. coding for kids说道:

    Excellent article. I’m experiencing a few of these issues as well..

  21. Greetings! Very helpful advice in this particular post! It’s the little changes that make the biggest changes. Many thanks for sharing!

  22. jambi prov说道:

    This is a topic which is close to my heart… Cheers! Where are your contact details though?

  23. MichaelLit说道:

    purple pharmacy mexico price list
    https://cmqpharma.online/# mexican border pharmacies shipping to usa
    mexico drug stores pharmacies

  24. HenryGainc说道:

    mexican mail order pharmacies: mexican online pharmacy – mexican mail order pharmacies

  25. You’ve provided a nuanced view on this topic.프라그마틱 슬롯 환수율

  26. Rodolfojox说道:

    mexican drugstore online
    http://cmqpharma.com/# buying prescription drugs in mexico
    purple pharmacy mexico price list

  27. IrvinSom说道:

    medication from mexico pharmacy: cmq pharma mexican pharmacy – medicine in mexico pharmacies

  28. 카카오 대출说道:

    This is a great resource for anyone interested in…35300만원 대출

  29. Your research really makes a difference.사업자 대출

  30. Arlen_P说道:

    Really good info can be found on web blog.!

  31. berita aceh说道:

    Having read this I thought it was rather informative. I appreciate you finding the time and energy to put this informative article together. I once again find myself spending a lot of time both reading and commenting. But so what, it was still worthwhile!

  32. porn说道:

    This is the perfect blog for everyone who hopes to find out about this topic. You realize a whole lot its almost hard to argue with you (not that I really will need to…HaHa). You definitely put a brand new spin on a subject that’s been written about for decades. Great stuff, just wonderful.

  33. tubidy mp3说道:

    Everything is very open with a precise description of the challenges. It was really informative. Your site is very useful. Thank you for sharing.

  34. Very nice blog post. I definitely appreciate this website. Thanks!

  35. escape room说道:

    hello there and thank you for your info – I have certainly picked up something new from right
    here. I did however expertise a few technical issues using this site, as I experienced to reload the website many times previous to
    I could get it to load correctly. I had been wondering if your hosting
    is OK? Not that I’m complaining, but slow loading instances times will very frequently affect
    your placement in google and can damage your high quality score if advertising and marketing with Adwords.
    Anyway I am adding this RSS to my email and can look out for a lot more
    of your respective exciting content. Make sure you update this again very
    soon.. Najlepsze escape roomy

  36. tubidy说道:

    Hi, I do think this is a great blog. I stumbledupon it 😉 I will revisit once again since I book-marked it. Money and freedom is the greatest way to change, may you be rich and continue to help other people.

  37. tubidy说道:

    This is a topic that’s near to my heart… Thank you! Where are your contact details though?

  38. harvard blog说道:

    Very good info. Lucky me I recently found your website by chance (stumbleupon). I’ve saved it for later!

  39. JohnieFag说道:

    mexican online pharmacies prescription drugs mexican pharmacy mexican pharmaceuticals online

  40. JeffreySlord说道:

    http://cmqpharma.com/# mexico drug stores pharmacies
    buying prescription drugs in mexico online

  41. JeffreySlord说道:

    https://cmqpharma.com/# mexican rx online
    mexican rx online

发表回复

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