上一期我们介绍了外观设计,这把我们聊聊让进度条跟随播放进度走
目录
预期效果
准备
- 在此之前,你需要有以下基础:
- 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>
- 最终效果:
- 默认是静音的,可以点击播放试试
While you exit, you get to know the cultures of different countries and whereas you will have experienced your individual culture, you’ll indeed discover the distinction between yours and the nation you might be visiting.
Previously, the cities of Kingston (for one day) and Knoxville in Jap Tennessee, and Murfreesboro, like Nashville located in Center Tennessee, had each served as the non permanent capital.
The early development of the queen in the Danvers Opening, additionally identified as the Parham Attack (2.Qh5), is usually played only by amateurs, though Hikaru Nakamura has experimented with it in grandmaster tournaments and was able to attain an inexpensive position.
Funeral providers were held Monday, Feb 18, at 2 p.m.
Other kinfolk also owned companies within the 1970’s in Carson Metropolis.
Malgus was positioned answerable for orbital safety, however the Sith Lord defied his orders and traveled back to Coruscant’s floor to strike towards the renegade Jedi Aryn Leneer, who needed to avenge her master Ven Zallow, killed by Malgus through the attack on the Jedi Temple.
The city challenged the attorney general’s authority to reject the annexation and electoral programs for each, as plaintiffs believed the reduction in seats and requirement for majority rating to win would dilute the voting power of the African-American minority.
buy Lisinopril 1st cheapest Lisinopril lisinopril1st
The People ended up holding the Convention Army in the course of the warfare.
24. McGourty, Colin (12 April 2023).
Till World War II, Tennessee, like most Southern states, remained predominantly agrarian.
Pennsylvania Affiliation of Family and Consumer Sciences Teacher of the Year in 2014, and in 2015 was an American Affiliation of Household and Client Science National Instructor of the Year Benefit Finalist.
Gallifrey had not really been erased from history, however an event horizon in relative time prevented anyone from Gallifrey’s past to travel past Gallifrey’s destruction, and vice versa.
The marches themselves have been brutal on the troopers, but their lives generally improved as soon as they got to their locations.
This site was… how do I say it? Relevant!! Finally I’ve found something which helped me. Thank you!
https://lisinopril1st.com/# buy Lisinopril online
There are implausible internships, and there are internships that are simply SO cool – and we are right here to tell you the perfect nine remote internships that will take you closer to your dream career.