读javascript高级程序设计12-HTML5脚本编程
一、跨文档消息传递(XDM)
1.发送消息
postMessage(msg,domain)用于发送跨文档消息。第一个参数是要传递的消息内容,第二个参数表示接收方来自哪个域。第二个参数有助于提高安全性,如果发现域不匹配则不会进行操作。
2.接收消息
接收到消息时,会触发window对象的message事件。传递给onmessage事件处理程序的对象主要包含三个信息:
- data:对应postMessage()第一个参数传入的内容;
- origin:发送消息的文档所在域。接收到消息后,检测消息来源是非常重要的步骤。
- source:发送消息的文档的window对象代理。
实例:
outer.html:
<body>
<span id="msg"></span>
<input type="text" id="input">
<input type="button" id="submit" value="提交">
<iframe width="300" height="150" src="inner.html" id="frame"></iframe>
<script type="text/javascript" src="EventUtil.js"></script>
<script type="text/javascript">
var btn = document.getElementById('submit');
//向iframe发送消息
EventUtil.addHandler(btn, 'click', function (event) {
var input = document.getElementById('input') .value;
var iframe = document.getElementById('frame') .contentWindow;
if (iframe.postMessage) {
iframe.postMessage(input, '*');
} else {
alert('do not support postMessage');
}
});
//接收iframe发送的消息
EventUtil.addHandler(window,'message',function(event){
var msg = document.getElementById('msg');
msg.innerHTML=event.data;
});
</script>
</body>
inner.html:
<body>
<span id="msg"></span>
<input type="text" id="input">
<input type="button" id="submit" value="提交">
<script type="text/javascript" src="EventUtil.js"></script>
<script type="text/javascript">
var msg = document.getElementById('msg');
//接收外层主窗体发送的消息
EventUtil.addHandler(window, 'message', function (event) {
msg.innerHTML = event.data;
});
var submit=document.getElementById("submit");
//向外层主窗体发送消息
EventUtil.addHandler(submit,'click',function(event){
if (parent.postMessage) {
var input = document.getElementById('input').value;
parent.postMessage(input, '*');
} else {
alert('do not support postMessage');
}
});
</script>
</body>
二、拖放
1. 拖放事件
被拖动元素会依次触发以下事件:
- dragstart:按下鼠标键并开始移动时触发;
- drag:在元素被拖动期间会持续触发该事件;
- dragend:拖动停止时触发。
当元素拖动到一个目标元素时,会依次触发以下事件:
- dragenter:元素被拖动到目标元素上时触发。
- dragover:被拖动的元素在目标元素范围内移动时会持续触发。
- dragleave或drop:当被拖动元素离开目标元素时触发dragleave。如果元素放到了目标元素中,则触发drop而不在触发dragleave。
虽然大多数元素支持拖放的目标元素事件,但是这些元素默认是不允许放置的。所以要使用preventDefault()取消这些元素的默认事件。
<img src="http://static.cnblogs.com/images/logo_small.gif" id="img" >
<div id="target" style="margin-right:10px;border:1px solid black; width:100px; height:100px;"></div>
<script type='text/javascript' src="EventUtil.js"></script>
<script type='text/javascript'>
var image = document.getElementById("img");
var handlerImg=function(event){
event=EventUtil.getEvent(event);
console.log(event.type);
}
EventUtil.addHandler(image, "dragstart", handlerImg);
EventUtil.addHandler(image, "drag", handlerImg);
EventUtil.addHandler(image, "dragend", handlerImg);
var handler=function(event){
event=EventUtil.getEvent(event);
event.preventDefault();
console.log(event.type);
}
var target=document.getElementById("target");
EventUtil.addHandler(target,"dragenter",handler);
EventUtil.addHandler(target,"dragover",handler);
EventUtil.addHandler(target,"dragleave",handler);
EventUtil.addHandler(target,"drop",handler);
</script>
2.dataTransfer对象
dataTransfer对象是事件对象的一个属性,用于从被拖动的元素向目标元素传递字符串类型的数据。保存在dataTransfer对象中的数据只能在ondrop事件中读取。几个常用方法:
- setData(type,value):设置用来设置数据。第一个参数是“Text”或者“url”,第二个参数是字符串类型的数据。text和url类型还是略有区别的,如果将数据保存为url,那么浏览器会把它当作网页中的链接。如果将其拖放到浏览器窗口中,浏览器就会打开该链接。
- getData(type):参数type是"Text"或“url”,与set中的设置保持一致。
- setDragImage(target,x,y):指定一幅图像,当拖动发生时,显示在光标下方。
<img src="http://static.cnblogs.com/images/logo_small.gif" id="img" >
<div id="target" style="float:left;margin-left:300px;border:1px solid black; width:200px; height:100px;"></div>
<script type='text/javascript' src="EventUtil.js"></script>
<script type='text/javascript'>
var image = document.getElementById('img');
var handlerImg = function (event) {
event = EventUtil.getEvent(event);
var target = EventUtil.getTarget(event);
event.dataTransfer.setData('Text', target.id);
event.dataTransfer.setData('url',target.getAttribute('src'));
event.dataTransfer.setDragImage(target,10,10);
}
EventUtil.addHandler(image, 'dragstart', handlerImg);
var handler = function (event) {
event = EventUtil.getEvent(event);
var target = EventUtil.getTarget(event);
switch (event.type) {
case 'drop':
event.preventDefault();
var id = event.dataTransfer.getData('Text');
var url=event.dataTransfer.getData('url');
target.appendChild(document.getElementById(id));
target.innerHTML+=url;
break;
case 'dragover':
event.preventDefault();
break;
}
}
var target = document.getElementById('target');
EventUtil.addHandler(target, 'dragover', handler);
EventUtil.addHandler(target, 'drop', handler);
</script>
3.可拖放
默认情况下,图像、文本等是可以拖动的,大多数其他元素不能拖动。如果想让某个元素可拖动,只需设置draggable=true即可。
<div id="target" style="border:1px solid black; width:200px; height:100px;" draggable="false"></div>
三、媒体元素
1.音频和视频控件
<audio id="player" src="billyBrowsers.ogg" poster="smile.gif" controls>不支持音频</audio>
<video id="player" src="billyBrowsers.ogg" poster="mymovie.jpg" width="300" height="200">不支持视频</video>
2.常用属性
autoplay:布尔型,设置是否自动播放。
controls:布尔型,用来设置浏览器中的自带控件是否显示。
currentSrc:当前播放的媒体文件url。
duration:媒体的总播放时间。
currentTime:当前已经播放的秒数。
loop:布尔型,媒体是否自动循环播放。
plaused:媒体播放器是否暂停。
src:媒体文件的来源。
<div class="mediaplayer">
<div class="video">
<audio id="player" src="billyBrowsers.ogg" poster="smile.gif" controls autoplay='true'>不支持音频</audio>
</div>
<div class="controls">
<input type="button" value="Play" id="audio-btn" />
<span id="curtime">0</span>/<span id="duration">0</span>
</div>
</div>
<script>
window.onload = function(){
var player = document.getElementById("player");
var btn = document.getElementById("audio-btn");
var curtime = document.getElementById("curtime");
var duration = document.getElementById("duration");
duration.innerHTML = player.duration;
EventUtil.addHandler(btn, "click", function(event){
if (player.paused){
console.log(player.currentSrc);
player.play();
btn.value = "Pause";
} else {
player.pause();
btn.value = "Play";
}
});
setInterval(function(){
curtime.innerHTML = player.currentTime;
}, 250);
};
</script>
3.Audio类型
<audio>元素有对应的构造函数Audio。其实不必将Audio插入到文档中,在创建Audio实例后就开始下载指定文件,下载完成后,调用play()方法就可以开始播放。
<script>
window.onload = function(){
var player=new Audio("billyBrowsers.ogg");
EventUtil.addHandler(player,"canplay",function(){
player.play();
})
};
</script>
读javascript高级程序设计12-HTML5脚本编程的更多相关文章
- 读javascript高级程序设计00-目录
javascript高级编程读书笔记系列,也是本砖头书.感觉js是一种很好上手的语言,不过本书细细读来发现了很多之前不了解的细节,受益良多.<br/>本笔记是为了方便日后查阅,仅作学习交流 ...
- 读javascript高级程序设计-目录
javascript高级编程读书笔记系列,也是本砖头书.感觉js是一种很好上手的语言,不过本书细细读来发现了很多之前不了解的细节,受益良多.<br/>本笔记是为了方便日后查阅,仅作学习交流 ...
- 读javascript高级程序设计08-引用类型之Global、Math、String
一.Global 所有在全局作用域定义的属性和方法,都属于Global对象. 1.URI编码: encodeURI():主要用于对整个URI编码.它不会对本身属于URI的特殊字符进行编码. encod ...
- 读javascript高级程序设计10-DOM
一.节点关系 元素的childNodes属性来表示其所有子节点,它是一个NodeList对象,会随着DOM结构的变化动态变化. hasChildNodes():是否有子节点. var headline ...
- 读javascript高级程序设计17-在线检测,cookie,子cookie
一.在线状态检测 开发离线应用时,往往在离线状态时把数据存在本地,而在联机状态时再把数据发送到服务器.html5提供了检测在线状态的方法:navigator.onLine和online/offline ...
- 读javascript高级程序设计01-基本概念、数据类型、函数
一. javascript构成 1.javascript实现由三部分组成: ECMAScript:核心语言功能 DOM:文档对象模型,提供访问和操作网页内容的方法和接口 BOM:浏览器对象模型,提供与 ...
- 读javascript高级程序设计14-错误处理与调试
一 错误类型 ECMA规定了常见的7种错误类型: Error: 基类型.其他常见的错误类型都继承自该类型,一般供开发人员抛出自定义错误. EvalError:该类型会在eval()函数使用异常时被抛 ...
- [已读]JavaScript高级程序设计(第3版)
从去年开始看,因为太长,总是没有办法一口气把它看完,再加上它与第二版大部分一致,读起来兴致会更缺一点. 与第二版相比,它最大的改变就是增加了很多html5的内容,譬如:Object对象的一些新东西,数 ...
- 读Javascript高级程序设计第三版第六章面向对象设计--创建对象
虽然Object构造函数或者对象字面量都可以用来创建单个对象,但是缺点非常明显:使用同一接口创建很多对象,会产生大量重复代码. 工厂模式 1 function CreatePerson(name,a ...
随机推荐
- EF CodeFirst 创建数据库
最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精 话说EF支持三种模式:Code First M ...
- WCF服务接口多,客户端在引用时出错!报WCF The maximum nametable character count quota (16384) has been exceeded while reading XML data错误
WCF服务接口多,客户端在引用时出错!报WCF The maximum nametable character count quota (16384) has been exceeded while ...
- 学习OpenCV——BOW特征提取函数(特征点篇)
没日没夜的改论文生活终于要告一段落了,比起改论文,学OpenCV就是一件幸福的事情.OpenCV的发展越来越完善了,已经可以直接使用BOW函数来进行对象分类了. 简单的通过特征点分类的方法: ...
- ACCESS自动编号清零
ACCESS的数据库,当每次删除所有记录后,表里的一个ID字段(自动编号),无限递增,位数无限扩.当每次执行删除查询时,程序就把“自动编号”型ID字段清零,然后重新从“初始值”开始,解决方法如下: ...
- Java语言中,类所拥有的“孩子”,他们的关系是怎样的
学习了一本有关Java的书.初步了解了一些面向对象的内容. java是由一个个的类组成的,这些类组成了java程序.类之下有他的孩子,这四个孩子分别是: 成员变量:就相当于一个个的变量,他由stati ...
- 如何在普清的屏上调试CSS样式二倍图背景
背景: 最近就遇到一个同事的项目,还是像平常一样小心切图,认真对像素. 一切测试都没有问题,顺利上线. 但是,上线之后,产品经理跑过来说,有BUG. BUG描述:(不认为是BUG) 前端页面上的图标是 ...
- CSS图片列表
1.效果图: 2.Example Source Code <h3><a href="http://www.52css.com/">我爱CSS画廊</a ...
- .naturalWidth 和naturalHeight属性,
在HTML 5中,新增加了两个用来判断图片的宽度和高度的属性,分别为 .naturalWidth 和naturalHeight属性,例子如下: var rw = myimage.naturalWidt ...
- CentOS配置SSH免密码登录后,仍提示输入密码
CentOS配置SSH无密码登录需要3步: 生成公钥和私钥 导入公钥到认证文件,更改权限 测试 1.生成公钥和私钥 ssh-keygen -t dsa -P '' -f ~/.ssh/id_dsa 默 ...
- python学习之安装模块
安装pip下载python模块 yum -y install python-pip pip install pandas (pandas要安装的模块名) 默认使用的官方python源,这个在国内访问很 ...