上一期我们介绍了外观设计,这把我们聊聊让进度条跟随播放进度走
目录
预期效果
准备
- 在此之前,你需要有以下基础:
- 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>
- 最终效果:
- 默认是静音的,可以点击播放试试
Pin Up Azerbaycan: pin-up kazino – pin-up kazino
https://autolux-azerbaijan.com/# pin-up kazino
Dzięki za to, że skomplikowane tematy SEO stały się bardziej przystępne.
pin-up kazino: Pin Up – pin-up kazino
https://autolux-azerbaijan.com/# Pin-up Giris
Pin Up: Pin-Up Casino – Pin Up Azerbaycan
Dziękuję za poruszenie tematu, który często jest pomijany, jakim jest SEO.
Pin up 306 casino: Pin Up Kazino ?Onlayn – Pin Up Azerbaycan
https://autolux-azerbaijan.com/# pin-up 141 casino
https://autolux-azerbaijan.com/# pin-up360
SEO to zdecydowanie nie jest projekt typu zrób to sam. Dzięki za ostrzeżenie!
pin-up kazino: pin-up360 – Pin up 306 casino
https://autolux-azerbaijan.com/# ?Onlayn Kazino
https://autolux-azerbaijan.com/# Pin up 306 casino
https://autolux-azerbaijan.com/# Pin Up Kazino ?Onlayn
Pin Up Azerbaycan ?Onlayn Kazino: Pin Up Kazino ?Onlayn – pin-up360
Pin-up Giris: Pin-Up Casino – Pin Up
https://autolux-azerbaijan.com/# Pin-Up Casino
Pin up 306 casino: pin-up kazino – ?Onlayn Kazino
Dzięki za praktyczne wskazówki dotyczące znalezienia wykwalifikowanego specjalisty SEO.
pin-up kazino: pin-up 141 casino – Pin Up Azerbaycan
https://autolux-azerbaijan.com/# Pin-up Giris
https://autolux-azerbaijan.com/# pin-up360
Świetne wskazówki dotyczące znalezienia wiarygodnych usług SEO. Dzięki!
Pin-Up Casino: Pin-up Giris – pin-up 141 casino
Pin up 306 casino: Pin Up Kazino ?Onlayn – pin-up360
Pin up 306 casino: pin-up360 – Pin-Up Casino
To była otwierająca oczy lektura na temat ryzyk i procesu SEO.
https://autolux-azerbaijan.com/# pin-up kazino
Pin Up Azerbaycan ?Onlayn Kazino: Pin Up Kazino ?Onlayn – Pin Up Azerbaycan
canadian drug pharmacy
To były bardzo pomocne informacje na temat kroków w SEO.
Very good post. I’m facing many of these issues as well..
Dzięki za jasne i zwięzłe informacje na temat SEO.
This will be a great website, might you be interested in doing an interview about how you developed it? If so e-mail me!
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: )
I used to be able to find good advice from your blog articles.
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!
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.
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.
Hey, great post you might be interested in some of my Web Design services I offer!
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
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!
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.
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.
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!…
Pretty! This was a really fantastic post. Thank you for your supplied information Sales Letter Software
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.
the best dating websites are those sites which also gives you some freebies and souvenirs~
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.