上一期我们介绍了外观设计,这把我们聊聊让进度条跟随播放进度走
目录
预期效果
准备
- 在此之前,你需要有以下基础:
- 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>
- 最终效果:
- 默认是静音的,可以点击播放试试
I dugg some of you post as I cerebrated they were handy handy
Good info. Lucky me I found your website by chance (stumbleupon). I’ve bookmarked it for later.
pharmacies en ligne certifiГ©es http://kamagraenligne.com/# Pharmacie Internationale en ligne
An intriguing discussion is worth comment. There’s no doubt that that you simply write much more about this topic, may possibly not become a taboo topic but
What a lovely blog. I’ll certainly be back. Please preserve writing!
pharmacie en ligne sans ordonnance: acheter mГ©dicament en ligne sans ordonnance – trouver un mГ©dicament en pharmacie
home furnitures that uses hardwoord is a great option because hardwoods last longer::
Some really great info , Gladiola I found this.
Thanks for the information provided! I was researching for this article for a long time, but I was not able to see a dependable source.
I’d must verify with you here. Which isn’t one thing I often do! I get pleasure from reading a put up that will make individuals think. Additionally, thanks for allowing me to comment!
Sometimes, blogging is a bit tiresome specially if you need to update more topics.“:”*
If I have writer’s block, I occasionally just create random words, and hopefully some idea will come from that. Take a pencil, or an empty Word document and just begin typing or composing words. Some thing is bound to hit you eventually. I used to just do these exercises where I did nothing but create random sentences without using punctuation. This helped my brain juices to flow, and it allowed me to create some short poems and short, short stories. Occasionally that rare moment when two words fit together perfectly to give you a great concept for a story occurs, and who knows? Maybe those two words can launch a series of books, or a series of plays, or the great American novel.
I don’t even know how I ended up here, but I thought this post was great. I don’t know who you are but definitely you’re going to a famous blogger if you aren’t already Cheers!… Heya i am for the first time here. I found this board and I find It really useful & it helped me out a lot. I hope to give something back and aid others like you aided me….
This is a great blog” and i want to visit this every day of the week .
heya. I notice that you’re most likely interested in building back-links and stuff. I’m promoting scrapebox auto approve link lists. If you’d like to trade ?
sports watches that are made from titanium are great, expensive and very lightweight::
You should experience a tournament personally of the greatest blogs on the web. I most certainly will suggest this site!
Strong blog. I acquired a lot of great information. I?ve been keeping an eye on this technology for some time. It?utes fascinating the manner it retains different, nevertheless a number of of the primary parts stay a similar. have you ever observed lots modification since Search engines created their own latest purchase in the field?
I will right away seize your rss as I can’t find your email subscription hyperlink or e-newsletter service. Do you’ve any? Please permit me realize in order that I may subscribe. Thanks!
Dead pent subject material , Really enjoyed looking at .
Greetings! Quick question that’s completely off topic. Do you know how to make your site mobile friendly? My weblog looks weird when viewing from my iphone. I’m trying to find a template or plugin that might be able to fix this problem. If you have any recommendations, please share. Appreciate it!
I’m curious to find out what blog system you are using? I’m having some small security problems with my latest blog and I would like to find something more secure. Do you have any solutions?
I was very happy to discover this great site. I wanted to thank you for ones time for this fantastic read!! I definitely really liked every part of it and i also have you book-marked to check out new information in your blog.
Audio started playing anytime I opened this blog, so frustrating!
there are many movie download sites on the internet and i need a bigger hard drive to save thoes movies..
Helpful info. Lucky me I found your website accidentally, and I am shocked why this accident didn’t came about in advance! I bookmarked it.
it is always a good idea to go green because we always want to help the environment“
Hi my friend! I want to say that this post is amazing, nice written and include approximately all significant infos. I’d like to see more posts like this .
Pretty! This was a really fantastic post. Thank you for your supplied information Sales Letter Software
Howdy! Do you know if they make any plugins to help with Search
Engine Optimization? I’m trying to get my site to rank for some targeted keywords but I’m not seeing very good success.
If you know of any please share. Kudos! You can read similar blog here:
Choose your escape room
I would be mendacity basically said i do not such as this article, in reality, I love this a great deal I needed to place upward a discuss right here. I must state maintain the good function, and that i will likely be arriving again for good since I already bookmarked the actual page.
there are wooden toys that uses artificial wood which lasts longer compared to organic wood,,
I am glad to be a visitor of this utter website ! , appreciate it for this rare info ! .
LCD TVs can really save you from high electricity bills and office space*
health foods that are organice and have natural source should be the stuff that we should take`
My partner and I absolutely love your blog and find almost all of your post’s to be just what I’m looking for. Would you offer guest writers to write content for yourself? I wouldn’t mind creating a post or elaborating on a lot of the subjects you write with regards to here. Again, awesome blog!
You’re the best, I just found your blog and wanted to say that I’ve truly enjoyed browsing your blog posts. After all I’ll be subscribing to your feed and I hope you write again very soon!
Hey! I know this is kinda off topic but I was wondering if you knew where I could locate a captcha plugin for my comment form? I’m using the same blog platform as yours and I’m having trouble finding one? Thanks a lot!
An intriguing discussion will probably be worth comment. There’s no doubt that that you simply write regarding this topic, it will not certainly be a taboo subject but usually consumers are not enough to communicate on such topics. An additional. Cheers
Many thanks for taking a few minutes to line this all out for us. This kind of blog post has been very helpful to me.
I’m new to your blog and i really appreciate the nice posts and great layout.”`-.;
Good post thanks, do you have a Facebook page for this site?
Ha ha… I was just surfing around and took a look at these reviews. I can’t believe that there’s still this much interest. Thanks for posting about this.
This article is dedicated to all those who know what is billiard table; to all those who do not know what is pool table; to all those who want to know what is billiards;
you use a great weblog here! if you’d like to earn some invite posts on my blog?
After study a number of the blog articles on the internet site now, we really appreciate your method of blogging. I bookmarked it to my bookmark web site list and are checking back soon. Pls have a look at my web page in addition and figure out what you believe.
The digital cigarette makes use of a battery and a small heating element the vaporize the e-liquid. This vapor can then be inhaled and exhaled
Whats up very cool web site!! Man .. Beautiful .. Superb .. I will bookmark your web site and take the feeds additionally…I am happy to find a lot of useful information here in the put up, we want develop extra techniques on this regard, thank you for sharing.
Hi I am so delighted I found your blog page, I really found you by accident, while I was browsing on Yahoo for something else, Anyways I am here now and would just like to say cheers for a incredible post and a all round interesting blog (I also love the theme/design), I don’t have time to look over it all at the minute but I have saved it and also added in your RSS feeds, so when I have time I will be back to read more, Please do keep up the excellent job.
i am looking for furniture stores that offer great discount when you buy in bulk quantitites,