常用方法

.play():用于音频视频的播放

.pause():用于音频视频的暂停

常用属性

 <audio src="Batmobile Battle Mode Reveal Music.mp3" autobuffer autoplay loop controls ></audio>

durantion:获取目标标签的音频视频文件的时长

loop:设置是否循环播放,有这个标签就循环播放

control:设置是否显示控制组件,有这个标签就显示

src:设置文件路径,可以为blob路径,也可以为base64路径,也可以为绝对路径

currentTime:获取或设置当前音频视频文件的播放时间

autoplay:设置是否自动播放,如果有该属性则打开页面时就自动播放

autobuffer:设置文件播放前是否自动缓存

常用事件

onloadstart:文件开始加载时触发

oncanplay:文件加载完成可以播放时触发

ondurationchange:文件时长发生变化时触发

onended:文件播放结束时触发

onplay:文件播放时触发

ontimeupdate:文件当前播放时间(即currentTime属性)发生变化时触发

some tips:

一、duration的获取

1.$("audio")[0].oncanplay = function(){
  console.log($(this)[0].duration);
}

2.$("audio")[0].ondurationchange = function(){
console.log($(this)[0].duration);
}

3、console.log($("audio")[0].duration);

第三句无法获得duration,duration获取必须在文件加载完成后才能获取。1,2都能获取。所以duration一般会和oncanplay、ondurationchange搭配使用

二、事件都是异步的

上面代码中,首先打印出来的是NaN,因为上面事件的完成需要一定时间,也就是关于duration的获取和渲染到标签中最好是在加载事件中完成,如

 $("audio")[0].oncanplay = function(){
$("textarea").val($(this)[0].duration);
}

而不是

 var time;
$("audio")[0].oncanplay = function(){
time = $(this)[0].duration;
}
$("textarea").val(time); //内容为NaN

三、durationchange的用法

durationchange虽然是时长改变时触发,但是根据以下代码:

1<audio src="Batmobile Battle Mode Reveal Music.mp3" autobuffer autoloop loop controls ></audio>

 $("audio")[0].ondurationchange = function(){
alert(1);
}
setTimeout(function(){
$("audio")[0].src = "Batmobile Battle Mode Reveal Music.mp3";
},3000);

可以输出两次1,也就是说只要只要文件重新加载,即便是同个文件,同样的时长,也会触发该事件

四、通过input里的file表单上传多媒体文件给多媒体标签

想到的方法及其可行性

1.利用jquery的val属性直接获取地址

 <input type="file" name="" id="">
<script type="text/javascript">
var input = document.querySelector("input");
input.onchange = function(){
console.log($(this).val());
}
</script>

获得的结果是格式为  储存盘:\fakepath\文件名称.格式

因为浏览器出于安全原因不允许直接获取本地文件,所以获得是屏蔽了真实地址的假地址,所以该方法不可行

2.利用FileReader对象获取

 <input type="file" name="" id="">
<script type="text/javascript">
$("input")[0].onchange = function(){
var reader = new FileReader();
reader.readAsDataURL(this.files[0]);
reader.onload = function(){
console.log(reader.result);
} }
</script>

可以获取文件地址base64形式(不是很了解),但是长度过长,由于是想利用localStoragr储存,储存不了太长,所以不可行

3.利用window.URL.createObjectURL()获取

 <input type="file" name="">
<script type="text/javascript">
$("input")[0].onchange = function(){
var url = window.URL.createObjectURL($(this)[0].files[0]);
console.log(url);
}
</script>

获得的是blob形式的地址,但是每次重启浏览器后的通个文件的blob的值是不一样的,所以无法实现长久储存的效果,不可行

4.利用浏览器会在标签的地址前面自动补全当前js文件所连接的html文件的文件路径的原理

 var url = "uploadMusic/" + this.files[0].name;

直接将地址写为html所在文件的该文件所在的子文件加名字即可,局限性:音频视频必须放在html同个文件夹中

总结:浏览器保存本地文件的想法不可行,因为浏览器要防止网页恶意读取用户客户端文件,没有意义,玩玩还行

Video/audio标签的一些基础使用心得的更多相关文章

  1. html5 video/audio 标签

    一般来说推荐使用,第三方的媒体播放库[例如 videojs 等],这些库的ui界面,js控制都已写好,功能也扩展的比较丰富 ,直接参考文档使用更加的高效! 这里还是 记录一下 html 原生 vide ...

  2. html5media.js 让浏览器兼容<Video><Audio> 标签

    介绍:https://html5media.info/ 项目:https://github.com/etianen/html5media Wiki:https://github.com/etianen ...

  3. html5之音频、视频(video&audio)

    音频&视频 本篇为本人的学习笔记. 在Html5之前,浏览器对于视频和音频的处理并没有一个标准.因此在网页中看到的视频,都是通过第三插件的方式嵌入的,如:QuickTime.RealPlaye ...

  4. <video>和<audio>标签

    一.<video>基本格式: <video width=" " heigh="" src=""> </vide ...

  5. <video>和<audio>标签,对视频和音频的支持

    H5新增了<video>和<audio>标签,提供对视频和音频的支持 <audio>的属性与<video>属性相同 <video> vide ...

  6. html5中的video标签和audio标签

    不管是否承认,flash早已不像过往那样如日中天了.亚马逊全面放弃flash.苹果放弃flash.安卓也放弃了移动端的flash支持.事实上flash已经不太适合web开发了,因为HTML5中的vid ...

  7. video标签、audio标签

    1.video标签 <video src="nans.mp4" controls="controls"  autoplay="autoplay& ...

  8. video/audio在ios/android上播放兼容

    1.audio自动播放 <audio src='xxx.mp3' autoplay></audio> 上面是audio标签autoplay属性是自动播放,但是在安卓部分浏览器和 ...

  9. 论HTML5 Audio 标签歌词同步的实现

    HTML5草案里面其实有原生的字幕标签(<track> Tag)的,但使用的是vtt格式的文件,非常规的字幕(.sub, .srt)或歌词文件(.lrc). 用法如下(代码来自W3Scho ...

随机推荐

  1. HDU-2795Billboard+对宽度建立线段树

    参考:  https://blog.csdn.net/qiqi_skystar/article/details/49073309 传送门:http://acm.hdu.edu.cn/showprobl ...

  2. atcoder C - Snuke and Spells(模拟+思维)

    题目链接:http://agc017.contest.atcoder.jp/tasks/agc017_c 题解:就是简单的模拟一下就行.看一下代码就能理解 #include <iostream& ...

  3. codeforces 805 D. Minimum number of steps(数学)

    题目链接:http://codeforces.com/contest/805/problem/D 题意:只有一个操作就是将ab变成bba直到不能变为止,问最少边几次. 题解:这题可以多列几组来找规律, ...

  4. hud 3555 Bomb 数位dp

    Bomb Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others) Total Subm ...

  5. pandas数据分析输出excel产生文本形式存储的百分比数据,如何处理?

    关键词: python.pandas.to_excel.文本形式存储的数据 需求描述: 我用 python pandas 写了数据统计与分析脚本,并把计算结果用 pandas 的 to_excel() ...

  6. 【Redis】SpringBoot+Redis+Ehcache实现二级缓存

    一.概述 1.1 一些疑惑? 1.2 场景 1.3 一级缓存.两级缓存的产生 1.4 流程分析 二.项目搭建 一.概述 1.1 一些疑惑? Ehcache本地内存 Redis 分布式缓存可以共享 一级 ...

  7. 026 模块3-random库的使用

    目录 一.random库基本介绍 1.1 random库概述 二.基本随机数函数 2.1 随机数种子 三.扩展随机数函数 3.1 随机数函数的使用 一.random库基本介绍 random库是使用随机 ...

  8. 谁动了我的奶酪?--java实例初始化的顺序问题

    故事背景 有一天,老鼠小白发现了一个奇怪的问题,它的奶酪的生产日期被谁搞丢了,不知道奶酪是否过期,可怎么吃呀? 让我们来看看吧 import java.util.Date;public class C ...

  9. 为什么Hashtable ConcurrentHashmap不支持key或者value为null

    ConcurrentHashmap HashMap和Hashtable都是key-value存储结构,但他们有一个不同点是 ConcurrentHashmap.Hashtable不支持key或者val ...

  10. Winform中使用zxing和Graphics实现自定义绘制二维码布局

    场景 zxing.dll下载 https://download.csdn.net/download/badao_liumang_qizhi/11623214 效果 实现 根据上面文章中将简单的二维码生 ...