上一期我们介绍了外观设计,这把我们聊聊让进度条跟随播放进度走
目录
预期效果
准备
- 在此之前,你需要有以下基础:
- 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>
- 最终效果:
- 默认是静音的,可以点击播放试试
mexican rx online: mexican pharmaceuticals online – mexican drugstore online
best online pharmacies in mexico: mexican northern doctors – mexico drug stores pharmacies
https://northern-doctors.org/# mexican rx online
https://northern-doctors.org/# mexico pharmacy
buying prescription drugs in mexico online: mexican mail order pharmacies – mexico pharmacy
mexican mail order pharmacies mexican pharmacy northern doctors п»їbest mexican online pharmacies
mexico pharmacy: Mexico pharmacy that ship to usa – mexican online pharmacies prescription drugs
An impressive share, I just now with all this onto a colleague who was conducting a small analysis within this. And hubby in truth bought me breakfast simply because I uncovered it for him.. smile. So let me reword that: Thnx with the treat! But yeah Thnkx for spending plenty of time to debate this, I’m strongly regarding this and really like reading on this topic. If possible, as you become expertise, do you mind updating your site with a lot more details? It is highly of great help for me. Big thumb up just for this text!
I’m extremely impressed with your writing skills as well as with the layout on your blog. Is this a paid theme or did you modify it yourself? Anyway keep up the excellent quality writing, it is rare to see a nice blog like this one nowadays..
http://northern-doctors.org/# mexican drugstore online
medicine in mexico pharmacies: northern doctors – buying from online mexican pharmacy
https://northern-doctors.org/# buying prescription drugs in mexico online
mexico drug stores pharmacies: Mexico pharmacy that ship to usa – medication from mexico pharmacy
mexico drug stores pharmacies northern doctors medication from mexico pharmacy
family counseling is sometimes needed because you cannot solve all your problems~
Hello my family member! I want to say that this article is amazing, great written and come with almost all important infos. I would like to look extra posts like this .
п»їbest mexican online pharmacies: Mexico pharmacy that ship to usa – mexican drugstore online
mexican drugstore online: northern doctors – mexico drug stores pharmacies
https://northern-doctors.org/# mexican online pharmacies prescription drugs
https://northern-doctors.org/# mexican online pharmacies prescription drugs
Surprisingly! It’s as if you read my mind! You appear to know therefore considerably relating to this, just like you wrote it in it or something. We feel that you simply can do with some pictures to drive the content residence a bit, on top of that, this really is great blog. A exceptional study. I will definitely revisit once more.
Simply added this web site to my top picks. I love reading through your own sites and we imagine you have them coming!
best online pharmacies in mexico: mexican pharmacy – mexico pharmacies prescription drugs
mexico pharmacies prescription drugs: Mexico pharmacy that ship to usa – mexican online pharmacies prescription drugs
mexico pharmacies prescription drugs mexican pharmacy online mexican border pharmacies shipping to usa
http://northern-doctors.org/# mexican pharmacy
http://northern-doctors.org/# buying prescription drugs in mexico online
I, for my friends in the class, wish to express our own thanks for the truly wonderful secrets revealed through your article. Your own clear explanation helped bring comfort and optimism to all of us and would certainly really help us in a research we are at this time doing. I think if still come across web pages like yours, my own stay in college is an easy one. Thanks
Thank you for the sensible critique. Me & my neighbor were just preparing to do some research about this. We got a grab a book from our area library but I think I learned more from this post. I am very glad to see such magnificent information being shared freely out there.
reputable mexican pharmacies online: medication from mexico pharmacy – mexican border pharmacies shipping to usa
mexico pharmacy: mexican pharmacy online – reputable mexican pharmacies online
Where do you come up with this? Just saying you are very imaginative. You should ask your readers for new topics.
You really should get involved in a tournament for example of the most effective blogs on the web. I am going to recommend this website!
buying from online mexican pharmacy northern doctors pharmacy medication from mexico pharmacy
https://northern-doctors.org/# buying prescription drugs in mexico
Johnny Depp is my idol. such an amazing guy ;
Really great info. I’m very happy to read this article. Thanks for sharing us nice articles.
Thanks for this advice I has been exploring all Yahoo to discover it!
Sometimes, blogging is a bit tiresome specially if you need to update more topics.,`,”~
The post offers verified useful to myself. It’s really informative and you’re simply obviously very knowledgeable in this area. You have got opened up my personal eye in order to various opinion of this particular matter together with intriquing, notable and solid content material.
I discovered your site web site on yahoo and check a number of your early posts. Preserve within the good operate. I simply additional increase RSS feed to my MSN News Reader. Seeking forward to reading a lot more within you later on!…
this song make sme cry, because my ex boyfriend sent me this when we were fighting….i would have done suicide that night i listened to this
magnificent issues altogether, you simply won emblem reader. What may you suggest in regards to your put up that you just made a few days in the past? Any positive?
canadian discount drugs
Dziękuję za poruszenie tematu, który często jest pomijany, jakim jest SEO.
Cieszę się, że znalazłem ten blog przed rozpoczęciem mojego projektu SEO.
https://autolux-azerbaijan.com/# pin-up kazino
pin-up kazino: pin-up 141 casino – pin-up360
pin-up360: Pin-up Giris – ?Onlayn Kazino
https://autolux-azerbaijan.com/# Pin Up