上一期我们介绍了外观设计,这把我们聊聊让进度条跟随播放进度走
目录
预期效果
准备
- 在此之前,你需要有以下基础:
- 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>
- 最终效果:
- 默认是静音的,可以点击播放试试
doxycyline online: doxycycline best price – antibiotic doxycycline
http://clomidca.com/# prednisone 20 mg prices
buy cheap zithromax online: amoxicillinca – zithromax capsules
doxycycline 100mg tablet price doxycycline azithromycinca doxycycline tablets australia
can i buy zithromax over the counter in canada: buy zithromax amoxicillinca – zithromax online usa no prescription
buy zithromax 500mg online buy zithromax online buy cheap zithromax online
amoxicillin 500mg over the counter: amoxil – amoxicillin 500mg
100 mg prednisone daily prednisone prednisone buy without prescription
where can i order doxycycline: doxycycline – buy doxycycline online canada
prednisone 20 tablet prednisone buy prednisone canada
prednisone uk over the counter: prednisone – prednisone 40 mg tablet
amoxicillin 500 mg tablet price cheapest amoxicillin order amoxicillin online no prescription
zithromax 1000 mg pills: zithromax – zithromax z-pak price without insurance
prednisone pharmacy clomidca.com prednisone 50
can i buy cheap clomid tablets: Clomiphene – can i buy clomid without insurance
can you buy doxycycline over the counter canada: azithromycinca – cheapest doxycycline without prescrtiption
where to get generic clomid without prescription Clomiphene order generic clomid pills
Greetings! Very useful advice within this post! It is the little changes that will make the largest changes. Many thanks for sharing!
online doxycycline azithromycinca.shop doxycycline 100 mg cap
where can i buy cheap clomid price best price how to get generic clomid price
where to get cheap clomid prices: cheap fertility drug – where can i get cheap clomid pill
zithromax prescription: cheapest Azithromycin – zithromax pill
doxycycline 10mg tablets doxycycline azithromycinca doxycycline 40 mg india
zithromax 500 mg lowest price drugstore online: zithromax – can i buy zithromax online
prednisone 4mg tab clomidca prednisone 20 mg purchase
doxycycline canadian online pharmacy: doxycycline – doxycycline order online canada
amoxicillin script amoxil doxycyclineca amoxicillin 500mg capsules antibiotic
where can i purchase zithromax online: Azithromycin best price – zithromax over the counter canada
amoxicillin 875 mg tablet amoxil doxycyclineca amoxicillin medicine over the counter
where can i buy prednisone: Deltasone – over the counter prednisone cream
http://azithromycinca.com/# doxycycline 10mg tablets
average cost of prednisone 20 mg clomidca.com 100 mg prednisone daily
order amoxicillin online no prescription: amoxil – generic amoxicillin cost
azithromycin amoxicillin: amoxil doxycyclineca – canadian pharmacy amoxicillin
This is a topic which is close to my heart… Many thanks! Exactly where are your contact details though?
Fantastic site. Lots of useful information here. I am sending it to a few pals ans also sharing in delicious. And certainly, thank you to your effort!
Lady Gaga is looking to get to be reincarnated as a ‘mean and ferocious version to do with herself in a future lifetime.
Very well-done blog. I especially appreciate content that has to do with health and fitness, so it’s refreshing to me to see what you have here. Keep it up! facial exercises
It’s perfect time to make some plans for the future and it’s time to be happy. I’ve read this post and if I could I desire to suggest you few interesting things or tips. Maybe you could write next articles referring to this article. I want to read more things about it!
Amaze! Thank you! I constantly wished to produce in my internet site a thing like that. Can I take element of the publish to my blog?
most reliable online pharmacy
I just additional this particular feed to be able to my book marks. I need to say, I seriously take pleasure in reading your own sites. Keep it up!
Audio began playing any time I opened up this blog, so frustrating!
The the next time I read a blog, I’m hoping who’s doesnt disappoint me about that one. I mean, I know it was my replacement for read, but I really thought youd have some thing fascinating to talk about. All I hear is really a number of whining about something you could fix when you werent too busy searching for attention.
I was really lucky to find this internet site on bing, just what I was searching for : D likewise saved to favorites .
Well worded post will be sharing this with my readers this evening
Additionally, it doesn’t matter how extremely you should be complete with treating a very platform, gradually you’ll discover an instance the places you should want to do a number instruct care; and as a consequence influenced by your real age but also bodybuilding, therfore the inches of one’s caravan it could be a awfully excessive pastime. motor movers
Ha ha… I was just surfing around and took a look at these feedback. I can’t believe that there’s still this much interest. Thanks for posting about this.
Thanks. I really like your site. Great points you make in your post.
Just wanted to give you a shout from the valley of the sun, great information. Much appreciated.