上一期我们介绍了外观设计,这把我们聊聊让进度条跟随播放进度走
目录
预期效果
准备
- 在此之前,你需要有以下基础:
- HTML/CSS/JS
- 了解一些<audio>标签的属性和事件
- Vue(数据绑定和事件绑定)
实现
- 还是上次的那个Html/css,但我们这把加入了:
- 最外围用div包裹,用于创建vue
- 添加了<audio>
- 显示音乐标签面板 (controls)
- 默认静音 (muted)
- 绑定事件:播放时长更新事件 timeupdate
- 绑定数据:音频文件资源链接 src
- 两个vue数据绑定
- cmusic_control_loadProgress_style (加载进度条长度)
- cmusic_control_progress_style (播放进度条长度)
- 修改部分css样式
- HTML:
<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>
- CSS:
<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>
- 并在script标签内写js/vue代码:
<!-- 引入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>
- 最终效果:
- 默认是静音的,可以点击播放试试
gay porn
https://artdaily.com/news/171650/Mp3Juice-Review–The-Pros-and-Cons-You-Need-to-Know
lesbian porn
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!
This is a topic that is close to my heart… Many thanks! Exactly where can I find the contact details for questions?
untrustable
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.
Very good article. I will be facing a few of these issues as well..
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.
Very good blog post. I absolutely appreciate this site. Thanks!
There are certainly a couple more details to take into consideration, but thanks for sharing this info.
i’m fond of using vending machines because you can instantly get a drink or a snack,
homosexual porn
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!
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.
online prescriptions canada without
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…
In this first movie, Spock and Kirk aside, perhaps, they seem to be pale imitations.
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.
online slot
This website certainly has all of the information I wanted about this subject and didn’t know who to ask.
Pretty! This was an incredibly wonderful post. Thank you for providing this info.
This site really has all the info I needed concerning this subject and didn’t know who to ask.
canadian drugs pharmacy
canadian online pharmacies reviews
homosexual porn
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.
Excellent article. I’m experiencing a few of these issues as well..
Greetings! Very helpful advice in this particular post! It’s the little changes that make the biggest changes. Many thanks for sharing!
This is a topic which is close to my heart… Cheers! Where are your contact details though?
purple pharmacy mexico price list
https://cmqpharma.online/# mexican border pharmacies shipping to usa
mexico drug stores pharmacies
mexican mail order pharmacies: mexican online pharmacy – mexican mail order pharmacies
I’ve learned a lot from reading your post.구글상위노출 seo작업
You’ve provided a nuanced view on this topic.프라그마틱 슬롯 환수율
mexican drugstore online
http://cmqpharma.com/# buying prescription drugs in mexico
purple pharmacy mexico price list
medication from mexico pharmacy: cmq pharma mexican pharmacy – medicine in mexico pharmacies
This is a great resource for anyone interested in…35300만원 대출
Your research really makes a difference.사업자 대출
Really good info can be found on web blog.!
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!
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.
Everything is very open with a precise description of the challenges. It was really informative. Your site is very useful. Thank you for sharing.
Very nice blog post. I definitely appreciate this website. Thanks!
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
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.
This is a topic that’s near to my heart… Thank you! Where are your contact details though?
Very good info. Lucky me I recently found your website by chance (stumbleupon). I’ve saved it for later!
mexican online pharmacies prescription drugs mexican pharmacy mexican pharmaceuticals online
http://cmqpharma.com/# mexico drug stores pharmacies
buying prescription drugs in mexico online
https://cmqpharma.com/# mexican rx online
mexican rx online