HTML5与CSS3权威指南.pdf5
第9章 通信API
跨文档消息传输
HTML5提供了网页文档之间互相接收与发送信息的功能,不仅同源(域+端口号)的Web网页之间可以互相通信,甚至可以实现跨域通信
想要接受从其他窗口发过来的信息,要对窗口对象的message事件进行监视
window.addEventListener("message",function(){...},false);
使用window对象的postMessage方法向其他窗口发送消息
otherWindow.postMessage(message,targetOrigin);
第一个参数为所发送的消息文本,也可以是任何的Javascript对象(通过JSON转换对象为文本);第二个参数为接受消息的对象窗口的URL地址(例如http://localhost:8080/),可以使用通配符“*”指定全部地址。otherWindow为要发送窗口对象的引用,可以通过window.open返回该对象,或通过对window.frames数组指定序号返回单个frame所属的窗口对象
1)通过访问message事件的origin属性,可以获取消息的发送源(发送源与网站的URL地址不是同一概念,发送源只包括域名与端口号,最好检查发送源)
2)message事件的data属性,可以获取消息内容(可以是任何Javascript对象)
3)postMessage方法发送消息
4)通过访问message事件的source属性,可以获取消息发送源的窗口对象(准确的说是窗口的代理对象)
JSON对象的stringify方法将Javascript对象转换成文本,使用parse方法将文本还原为Javascript对象,任何Javascript对象可以通过这种方式在网页文档、端口、域之间传递消息
Web Sockets通信
Web Sockets是HTML5提供的在应用程序中客户端与服务器端之间进行的非HTTP通信机制,它实现了用HTTP不容易实现的服务器端的数据推送等智能通信技术
建立一个非HTTP的双向连接(实时永久,除非被显式关闭),客户端只要有一个被打开的套接字与服务器建立了连接,服务器就可以把数据推送过来,从被动到主动
使用Web Socket API
将URL字符串作为参数,然后调用构造器
var webSocket=new WebSocket("ws://localhost:8005/socket");
URL字符串必须以“ws”、“wss(加密通信时)”文字作为开头,javascript脚本中可以通过访问WebSocket对象的url属性来重新获取,使用WebSocket对象的send方法对服务器发送数据
webSocket.send("data");
通过获取onmessage事件句柄来接收服务器传过来的数据
webSocket.onmessage=function(event){
var data=event.data;
...
}
通过获取onopen事件句柄来监听socket的打开事件
webSocket.onopen=function(event){
//开始通信时的处理
};
获取onclose事件句柄来监听socket的关闭事件
webSocket.onclose=function(event){
//通信结束时的处理
};
通过使用close方法来关闭socket,切断通信连接
webSocket.close();
另外还可以通过读取readyState属性值来获取WebSocket对象的状态
CONNECTING(数字为0)表示正在连接 OPEN(数字为1)表示正在建立连接 CLOSING(数字为2)表示正在关闭连接 CLOSED(数字为2)表示已关闭连接
第10章 使用Web Workers处理线程
var worker=new Worker("worker.js");
需要注意的是,后台线程中不能访问页面或窗口对象,如果使用到则会引发错误
在后台线程中接收消息
worker.onmessage=function(event){
//处理接收到的消息
}
对后台线程发送消息
work.postMessage(message); //文本数据
线程嵌套:线程中可以嵌套子线程,把一个较大的后台线程切成几个子线程,在每个子线程中完成相对独立的一部分
在多个子线程中进行数据的交互,步骤如下
1)先创建发送数据的子线程
2)子线程执行任务,再传给主线程
3)再创建一个子线程,将主线程中的数据传给新的子线程
4)新的子线程执行代码
线程中可用的变量、函数与类
self:本线程范围内的作用域
postMessage(message):向创建的源窗口发送信息
onmessage:接收消息的事件句柄
importScript(urls):导入其他Javascript脚本文件,可以是多个,导入的文件与使用该线程文件的页面必须是同一个域、同一个端口中
importScripts('script1.js','scripts\script2.js');
navigator对象:与window.navigator对象类似
sessionStorage/localStorage:可以在线程中使用WebStorage
XMLHttpRequest:可以在线程中使用Ajax请求
Web Workers:可以在线程中嵌套线程
setTimeout()/setInterval():线程中实现定时处理
close:结束本线程
eval()、isNan()等:可以使用Javascript核心函数
object:可以创建和使用本地对象
WebSockets:可以使用WebSocketsAPI向服务器发送和接收信息
HTML5与CSS3权威指南.pdf5的更多相关文章
- Html5与CSS3权威指南 百度云下载
Html5与CSS3权威指南 百度云下载 链接:http://pan.baidu.com/s/1hq6Dlvm 密码:php3
- HTML5与CSS3权威指南之CSS3学习记录
title: HTML5与CSS3权威指南之CSS3学习记录 toc: true date: 2018-10-14 00:06:09 学习资料--<HTML5与CSS3权威指南>(第3版) ...
- 【HTML5 4】《HTML5与CSS3权威指南》 step1 导读
一.教程重点:以 HTML5和CSS3的新功能和新特性 为导向,辅之以 实战型实例页面 二.内容概况: 第1部分:详细讲解HTML5相关知识,包括 各主流浏览器对HTML5的支持情况. HTML5与H ...
- HTML5与CSS3权威指南.pdf6
第11章 获取地理位置信息 HTML5为window.navigator对象新增了一个geolocation属性 取得当前地理位置 void getCurrentPosition(onSuccess, ...
- HTML5与CSS3权威指南笔记案例1
第1章 <!DOCTYPE html> <meta charset = "UTF-8"> <title> Search </title&g ...
- HTML5与CSS3权威指南
第一章:Web时代的变迁 HTML5放心使用的理由: 兼容性:HTML5在老板本的浏览器上也可以正常运行: 实用性:HTML5内部并没有封装什么很复杂的,不切实际的功能,而只是封装了简单实用的功能: ...
- 读《HTML5与CSS3权威指南(上册)》笔记
第二章 1.内容类型:“text/html”.DOCTYPE声明:<!DOCTYPE html>.指定字符编码:<meta charset="utf-8"> ...
- HTML5与CSS3权威指南.pdf9
第21章 Media Queries相关样式 该模块中允许添加媒体查询(media query)表达式,用以指定媒体类型,根据媒体类型来选择使用的样式(显示器.便携设备.电视机) 使用方法@media ...
- HTML5与CSS3权威指南.pdf8
第17章 与背景和边框相关的样式 与背景相关的新增属性 background-clip指定背景的显示范围 background-origin指定绘制背景图像时的起点 background-size指定 ...
随机推荐
- hrbust 1328 相等的最小公倍数(数论)
Description 定义An为1,2,-,n的最小公倍数,例如,A1 = 1,A2 = 2,A3 = 6,A4 = 12,A5 = 60,A6 = 60. 请你判断对于给出的任意整数n,An是否等 ...
- ASP.NET缓存 Cache
缓存介绍 如果每次进入页面的时候都查询数据库生成页面内容的话,如果访问量非常大,则网站性能会非常差,而如果只有第一次访问的时候才查询数据库生成页面内容,以后都直接输出内容,则能提高系统性能,这样无论多 ...
- ubuntu ll命令
用过 Redhat 的朋友应该很熟悉 ll 这个命令,就相当于 ls -l,但在 Ubuntu 中就不行了.严格来说 ll 不是一个命令,只是命令的别名而已.很多 Linux 用户都使用 bash s ...
- linux磁盘以及文件系统
df 查看磁盘总容量 -i 显示inodes号 -h 使用合适的单位显示磁盘大小 -m 以M为单位显示 -k 以K为单位显示 默认K显示 du 用来查看某个目录或者文件所占空间大小 参数:-abckm ...
- SQLite学习第01天:参考资料
今天开始学习数据库相关的知识,由于本人从事的是嵌入式软件开发方向,所以在数据库的选择时就果断选择了SQLite,在网上搜索了一下相关的资料并且配置好了环境.首先,想要对SQLite有一个基本的了解还是 ...
- dom例子
//凡是html标签中的属性和值是一样的,那么在js中用true或者false 1,阅读协议倒计时 <input type="button" name="name& ...
- demo——06弹性和制作骰子
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- PHP - 《高性能php应用开发》学习笔记
一.基准测试 php网站优化最佳实践:优化前端(压缩js/css/images)--->程序优化(编码最佳实践.opcode缓存.变量/数据缓存)--->数据库.服务器调优-->操作 ...
- thinkphp+mysql+bootstrap
#thinkphp+mysql+bootstrapthinkphp3.2.3,bootstrap V3一个简易的企业cms网站系统,只要将clients的host改为对应的域名即可.thinkphp. ...
- html锚点
ID模式 <h3><a href="#start">开始</a></h3> <div> 你好 <b/> &l ...