jQuery多媒体插件jQuery Media Plugin使用详解


Posted in Javascript onDecember 19, 2014

jQuery Media Plugin是一款基于jQuery的网页媒体播放器插件,它支持大部分的网络多媒体播放器和多媒体格式,比如:Flash, Windows Media Player, Real Player, Quicktime, MP3,Silverlight, PDF。它根据当前的脚本配置,自动将a标签替换成div,并生成object, embed甚至是iframe代码,至于生成object还是embed,jQuery Media会根据当前平台自动判别,因此兼容性方面非常出色。下面这段代码是jQuery Media生成后的结果:

 <div class="media"> 

    <object width="450" height="250" attr1="attrValue1" attr2="attrValue2"

        codebase="http://www.apple.com/qtactivex/qtplugin.cab"

        classid="clsid:02BF25D5-8C17-4B23-BC80-D3488ABDDC6B"> 

        <param name="src"      value="myBetterMovie.mov"> 

        <param name="autoplay" value="true"> 

        <param name="param1"   value="paramValue1"> 

        <param name="param2"   value="paramValue2"> 

        <embed width="450" height="250" src="myBetterMovie.mov" autoplay="true"

            attr1="attrValue1" attr2="attrValue2" param1="paramValue1" param2="paramValue2"

            pluginspage="http://www.apple.com/quicktime/download/" > </embed> 

    </object> 

</div>

具体使用方法

html标记代码

<a class="media" href="sample.mov">My Quicktime Movie</a>

<a class="media" href="sample.swf">My Flash Movie</a>

<a class="media" href="sample.wma">My Audio File</a>

初始化脚本:

$('.media').media();

选项

可以通过脚本对象或者jQuery Metadata Plugin来配置参数。

全局默认值:

$.fn.media.defaults = {

preferMeta: 1, // 如果为true, 则标记的meta值优先于脚本对象

autoplay: 0, // 标准化的跨播放器设置

bgColor: '#ffffff', // 背景颜色

params: {}, // 作为param元素添加到object标记中;作为属性添加到embed标记中

attrs: {}, // 作为属性添加到object以及embed中

flashvars: {}, // 作为flashvars参数或属性添加到flash中

flashVersion: '7', // 需要的最低flash版本

// 默认的flash视频和mp3播放器 // @see: http://jeroenwijering.com/?item=Flash_Media_Player

flvPlayer: 'mediaplayer.swf',

mp3Player: 'mediaplayer.swf',

// Silverlight选项 // @see http://msdn2.microsoft.com/en-us/library/bb412401.aspx

silverlight: {

  inplaceInstallPrompt: 'true', // 在适当的位置显示安装提示

  isWindowless: 'true', // 无窗口模式

  framerate: '24', // 最大帧速率

  version: '0.9', // Silverlight版本 onError: null, // onError回调函数

  onLoad: null, // onLoad回调函数

  initParams: null, // 对象初始化参数

  userContext: null // 传到load回调函数的参数

  }

};

我们也可以在执行初始化脚本的时候传入一些option参数进去,如下代码:

$('.media').media( { width: 400, height: 300, autoplay: true } );

再如代码:

$('.media').media({

  width: 450,

  height: 250,

  autoplay: true,

  src: 'myBetterMovie.mov',

  attrs: { attr1: 'attrValue1', attr2: 'attrValue2' }, // object/embed attrs

  params: { param1: 'paramValue1', param2: 'paramValue2' }, // object params/embed attrs

  caption: false // supress caption text

});

'src'选项

src选项指定了媒体文件的地址。它没有全局的默认值。如果未显示指定src选项的值,jQuery Media Plugin将使用href或者src属性的值来代替。

播放器和格式

jQuery Media Plugin默认为播放器和格式如下表所示:

播放器 文件格式
Quicktime aif,aiff,aac,au,bmp,gsm,mov,mid, midi,mpg,mpeg,mp4,m4a,psd,qt,qtif, qif,qti,snd,tif,tiff,wav,3g2,3pg
Flash flv, mp3, swf
Windows Media Player asx, asf, avi, wma, wmv
Real Player ra, ram, rm, rpm, rv, smi, smil
Silverlight xaml
iframe html, pdf

上表说明了,mp3格式被自动对应到了flash播放器。全局配置中的$.fn.media.defaults.mp3Player指定MP3媒体由 mediaplayer.swf文件播放。该swf文件是一个小型的mp3和flash视频播放器,可以从这里下载:http://www.longtailvideo.com/players/jw-flv-player/

SWFObject

这个脚本很常见,用来将Flash内容嵌入到网页中,你不用考虑不同平台的Flash嵌入方式。但这个文件并非必需。如果它加载了,jQuery Media Plugin将使用它,反之jQuery Media Plugin将按自己的默认方式生成object/embed标记。更多信息可以参考:http://code.google.com/p/swfobject/

iframe Player

默认情况下,PDF和HTML格式被映射到了iframe。它们将显示在iframe中而非object/embed标记中。

添加或者修改格式关联

这个操作可以由插件的mapFormat方法实现,如

$.fn.media.mapFormat('mp3','quicktime');
可用的播放器有:uicktime, flash, realplayer, winmedia, silverlight和iframe,确保播放器能够播放关联到它的文件格式。

下载

直接下载jquery.media.js文件,或者在Github上下载历史版本

注意:

此插件会把<a>转化为<div> 从而嵌套多媒体内容。此插件像其它的Jquery插件一样 简单易用。

Javascript 相关文章推荐
javascript中的void运算符语法及使用介绍
Mar 10 Javascript
如何使用jQuery来处理图片坏链具体实现步骤
May 02 Javascript
js遍历、动态的添加数据的小例子
Jun 22 Javascript
js实时获取系统当前时间实例代码
Jun 28 Javascript
css样式标签和js语法属性区别
Nov 06 Javascript
jquery实现的图片点击滚动效果
Apr 29 Javascript
jQuery插件制作之参数用法实例分析
Jun 01 Javascript
最丑的时钟效果!js canvas时钟制作方法
Aug 15 Javascript
详解Angular的8个主要构造块
Jun 20 Javascript
史上最全JavaScript常用的简写技巧(推荐)
Aug 17 Javascript
利用jsonp与代理服务器方案解决跨域问题
Sep 14 Javascript
vue中 v-for循环的用法详解
Feb 19 Javascript
jquery图片播放浏览插件prettyPhoto使用详解
Dec 19 #Javascript
js中匿名函数的创建与调用方法分析
Dec 19 #Javascript
浅谈Javascript中匀速运动的停止条件
Dec 19 #Javascript
浅谈Javascript如何实现匀速运动
Dec 19 #Javascript
Javascript添加监听与删除监听用法详解
Dec 19 #Javascript
Javascript 实现图片无缝滚动
Dec 19 #Javascript
使用JavaScript获取地址栏参数的方法
Dec 19 #Javascript
You might like
关于session在PHP5的配置文件中的详细设置参数说明
2011/04/20 PHP
php连接oracle数据库及查询数据的方法
2014/12/29 PHP
clientX,pageX,offsetX,x,layerX,screenX,offsetLeft区别分析
2010/03/12 Javascript
jQuery+ajax实现鼠标单击修改内容的思路
2014/06/29 Javascript
图文详解Heap Sort堆排序算法及JavaScript的代码实现
2016/05/04 Javascript
浅谈jquery拼接字符串效率比较高的方法
2017/02/22 Javascript
jQuery查找dom的几种方法效率详解
2017/05/17 jQuery
微信小程序实现多个按钮toggle功能的实例
2017/06/13 Javascript
说说AngularJS中的$parse和$eval的用法
2017/09/14 Javascript
详解tween.js的使用教程
2017/09/14 Javascript
JS面试题大坑之隐式类型转换实例代码
2018/10/14 Javascript
微信小程序如何获取手机验证码
2018/11/04 Javascript
浅谈layui框架自带分页和表格重载的接口解析问题
2019/09/11 Javascript
js实现简易计算器功能
2019/10/18 Javascript
vue 实现走马灯效果
2019/10/28 Javascript
js+audio实现音乐播放器
2020/09/13 Javascript
vue 全局封装loading加载教程(全局监听)
2020/11/05 Javascript
[05:13]2018DOTA2亚洲邀请赛主赛事第二日战况回顾 LGD、VG双雄携手晋级
2018/04/05 DOTA
python基础教程之循环介绍
2014/08/29 Python
Python3.5实现的罗马数字转换成整数功能示例
2019/02/25 Python
分享8个非常流行的 Python 可视化工具包
2019/06/05 Python
python flask框架实现传数据到js的方法分析
2019/06/11 Python
解决python打开https出现certificate verify failed的问题
2020/09/03 Python
Python用dilb提取照片上人脸的示例
2020/10/26 Python
python中entry用法讲解
2020/12/04 Python
html5 touch事件实现触屏页面上下滑动(二)
2016/03/10 HTML / CSS
比驿:全球酒店比价网
2018/06/20 全球购物
精选鞋类、服装和配饰的全球领先目的地:Bodega
2021/02/27 全球购物
毕业生就业自荐信
2013/12/04 职场文书
18岁生日感言
2014/01/12 职场文书
小学师德标兵先进事迹材料
2014/05/25 职场文书
金融与证券专业求职信
2014/06/22 职场文书
我们的节日中秋活动方案
2014/08/19 职场文书
交通事故赔偿协议书
2014/10/16 职场文书
全国爱眼日活动总结
2015/02/27 职场文书
Python获取指定日期是"星期几"的6种方法
2022/03/13 Python