H5新特性---Web Worker---Web Stroage
今天的目标
3.1:h5新特性八--Web Worker---代码就3行
程序:program 存储在外存(磁盘)中代码
进程:Process/Task 将程序调用内存中,分配空间
线程:Thread 线程是进程内部代码基本单位
(1)进程是操作系统分配内存的基本单位
(2)线程是CPU执行代码的基本单位
(3)一个进程内部都多个线程组成,至少一个
(4)多个线程之间"并发执行的",宏观上看同时执行,
微观上看依次循环执行
chorme浏览器
一个 chrome进程内,有多个线程,负责向WEB服务器并发的发起请求,以获取资源: 请求资源线程
还有一个线程将所有内容绘制浏览器中--UI主线程,
还负责执行js/css代码.
观察如下代码
<button>按钮一</button>
<script src="x.js">很耗时js任务</script>
<button>按钮二</button>
现象:js执行代码中,按钮一可见,按钮2不可见
原因:浏览器执行代码和渲染网页同一个线程
解决:创建新线程,由它来执行耗时js任务,
UI主线程负责渲染网页.
代码:
<button>按钮一</button>
<script>
var w = new Worker("x.js");
</script>
<button>按钮二</button>
3.2:Worker线程缺陷
浏览器不允许Worker线程执行任何DOM/BOM操作
原因:浏览器只允许UI线程操作DOM/BOM,若多个
线程同时操作DOM/BOM页面,混乱..
所以类似jquery脚本不能使用Worker来执行
3.3:Worker线程可以给UI线程发送数据
worker:
postMessage(strMessage);
ui:
var w = new Worker("x.js");
w.onmessage = function(e){e.data}
3.4:UI线程可以给Worker线程发送数据
ui:
var w = new Worker("x.js");
w.postMessage(stringmeg);
worker:
onmessage = function(e){e.data}
练习: (1)在HTML中有一个INPUT,请用户输入数字,
(2)添加按钮"开始计算累加和"
(3)<div id="rs"></div>
点击此按钮,创建Worker 线程来计算出用户
输入数字累加和,在下方创建div显示计算结果

|
项目中Worker的使用场景 (1)只要js中有DOM/BOM就不能用Worker (2)Worker适合于执行耗时JS任务, 复杂计算,数据统计.. |
3.5:h5新特性九--Web Stroage
在浏览器中存储一些用户专用数据:内容定制,样式定制..
在客户端存储数据可以使用的技术
(1)cookie技术,浏览器兼容性好,不能超4KB,操作复杂
(2)Flash存储,依赖Flash播放器
(3)H5 WebStorage,不能超8MB,操作简单
(4)IndexDB 可存大量数据,还不是标准
|
Session:会话(用户操作过程)浏览器从打开某一个网站第一页面开始.(会话开始),中间可能打开多个页面(会话中),直到关闭浏览器(会话结束) |
WebStorage技术中,为用户提供二个对象
(1)sessionStorage 类数组对象,会话级数据存储
保存数据 sessionStorage[key] = value
保存数据 sessionStorage.setItem(key,value);
获取数据 var value = sessionStorage[key];
获取数据 var value = sessionStorage.getItem(key);
删除数据 sessionStorage.removeItem(key);
删除数据 sessionStorage.clear();
数据个数 sessionStorage.length
获取key var key = sessionStorage.key(i);
创建login.html 输入用户名,密码,提交,用户点击
提交按钮,提示"登录成功,3s后自动跳转 首页"
返回index.html 右上角 欢迎回来 xxx 退出登录
创建logout.html 提示"您己退出登录,3s后自动跳转首页"
返回index.html 右上角提示"请登录"超链接
(2)localStroage今天的目标
3.1:h5新特性八--Web Worker---代码就3行
程序:program 存储在外存(磁盘)中代码
进程:Process/Task 将程序调用内存中,分配空间
线程:Thread 线程是进程内部代码基本单位
(1)进程是操作系统分配内存的基本单位
(2)线程是CPU执行代码的基本单位
(3)一个进程内部都多个线程组成,至少一个
(4)多个线程之间"并发执行的",宏观上看同时执行,
微观上看依次循环执行
chorme浏览器
一个 chrome进程内,有多个线程,负责向WEB服务器并发的发起请求,以获取资源: 请求资源线程
还有一个线程将所有内容绘制浏览器中--UI主线程,
还负责执行js/css代码.
观察如下代码
<button>按钮一</button>
<script src="x.js">很耗时js任务</script>
<button>按钮二</button>
现象:js执行代码中,按钮一可见,按钮2不可见
原因:浏览器执行代码和渲染网页同一个线程
解决:创建新线程,由它来执行耗时js任务,
UI主线程负责渲染网页.
代码:
<button>按钮一</button>
<script>
var w = new Worker("x.js");
</script>
<button>按钮二</button>
3.2:Worker线程缺陷
浏览器不允许Worker线程执行任何DOM/BOM操作
原因:浏览器只允许UI线程操作DOM/BOM,若多个
线程同时操作DOM/BOM页面,混乱..
所以类似jquery脚本不能使用Worker来执行
3.3:Worker线程可以给UI线程发送数据
worker:
postMessage(strMessage);
ui:
var w = new Worker("x.js");
w.onmessage = function(e){e.data}
3.4:UI线程可以给Worker线程发送数据
ui:
var w = new Worker("x.js");
w.postMessage(stringmeg);
worker:
onmessage = function(e){e.data}
练习: (1)在HTML中有一个INPUT,请用户输入数字,
(2)添加按钮"开始计算累加和"
(3)<div id="rs"></div>
点击此按钮,创建Worker 线程来计算出用户
输入数字累加和,在下方创建div显示计算结果

|
项目中Worker的使用场景 (1)只要js中有DOM/BOM就不能用Worker (2)Worker适合于执行耗时JS任务, 复杂计算,数据统计.. |
3.5:h5新特性九--Web Stroage
在浏览器中存储一些用户专用数据:内容定制,样式定制..
在客户端存储数据可以使用的技术
(1)cookie技术,浏览器兼容性好,不能超4KB,操作复杂
(2)Flash存储,依赖Flash播放器
(3)H5 WebStorage,不能超8MB,操作简单
(4)IndexDB 可存大量数据,还不是标准
|
Session:会话(用户操作过程)浏览器从打开某一个网站第一页面开始.(会话开始),中间可能打开多个页面(会话中),直到关闭浏览器(会话结束) |
WebStorage技术中,为用户提供二个对象
(1)sessionStorage 类数组对象,会话级数据存储
保存数据 sessionStorage[key] = value
保存数据 sessionStorage.setItem(key,value);
获取数据 var value = sessionStorage[key];
获取数据 var value = sessionStorage.getItem(key);
删除数据 sessionStorage.removeItem(key);
删除数据 sessionStorage.clear();
数据个数 sessionStorage.length
获取key var key = sessionStorage.key(i);
创建login.html 输入用户名,密码,提交,用户点击
提交按钮,提示"登录成功,3s后自动跳转 首页"
返回index.html 右上角 欢迎回来 xxx 退出登录
创建logout.html 提示"您己退出登录,3s后自动跳转首页"
返回index.html 右上角提示"请登录"超链接
(2)localStroage今天的目标
3.1:h5新特性八--Web Worker---代码就3行
程序:program 存储在外存(磁盘)中代码
进程:Process/Task 将程序调用内存中,分配空间
线程:Thread 线程是进程内部代码基本单位
(1)进程是操作系统分配内存的基本单位
(2)线程是CPU执行代码的基本单位
(3)一个进程内部都多个线程组成,至少一个
(4)多个线程之间"并发执行的",宏观上看同时执行,
微观上看依次循环执行
chorme浏览器
一个 chrome进程内,有多个线程,负责向WEB服务器并发的发起请求,以获取资源: 请求资源线程
还有一个线程将所有内容绘制浏览器中--UI主线程,
还负责执行js/css代码.
观察如下代码
<button>按钮一</button>
<script src="x.js">很耗时js任务</script>
<button>按钮二</button>
现象:js执行代码中,按钮一可见,按钮2不可见
原因:浏览器执行代码和渲染网页同一个线程
解决:创建新线程,由它来执行耗时js任务,
UI主线程负责渲染网页.
代码:
<button>按钮一</button>
<script>
var w = new Worker("x.js");
</script>
<button>按钮二</button>
3.2:Worker线程缺陷
浏览器不允许Worker线程执行任何DOM/BOM操作
原因:浏览器只允许UI线程操作DOM/BOM,若多个
线程同时操作DOM/BOM页面,混乱..
所以类似jquery脚本不能使用Worker来执行
3.3:Worker线程可以给UI线程发送数据
worker:
postMessage(strMessage);
ui:
var w = new Worker("x.js");
w.onmessage = function(e){e.data}
3.4:UI线程可以给Worker线程发送数据
ui:
var w = new Worker("x.js");
w.postMessage(stringmeg);
worker:
onmessage = function(e){e.data}
练习: (1)在HTML中有一个INPUT,请用户输入数字,
(2)添加按钮"开始计算累加和"
(3)<div id="rs"></div>
点击此按钮,创建Worker 线程来计算出用户
输入数字累加和,在下方创建div显示计算结果

|
项目中Worker的使用场景 (1)只要js中有DOM/BOM就不能用Worker (2)Worker适合于执行耗时JS任务, 复杂计算,数据统计.. |
3.5:h5新特性九--Web Stroage
在浏览器中存储一些用户专用数据:内容定制,样式定制..
在客户端存储数据可以使用的技术
(1)cookie技术,浏览器兼容性好,不能超4KB,操作复杂
(2)Flash存储,依赖Flash播放器
(3)H5 WebStorage,不能超8MB,操作简单
(4)IndexDB 可存大量数据,还不是标准
|
Session:会话(用户操作过程)浏览器从打开某一个网站第一页面开始.(会话开始),中间可能打开多个页面(会话中),直到关闭浏览器(会话结束) |
WebStorage技术中,为用户提供二个对象
(1)sessionStorage 类数组对象,会话级数据存储
保存数据 sessionStorage[key] = value
保存数据 sessionStorage.setItem(key,value);
获取数据 var value = sessionStorage[key];
获取数据 var value = sessionStorage.getItem(key);
删除数据 sessionStorage.removeItem(key);
删除数据 sessionStorage.clear();
数据个数 sessionStorage.length
获取key var key = sessionStorage.key(i);
创建login.html 输入用户名,密码,提交,用户点击
提交按钮,提示"登录成功,3s后自动跳转 首页"
返回index.html 右上角 欢迎回来 xxx 退出登录
创建logout.html 提示"您己退出登录,3s后自动跳转首页"
返回index.html 右上角提示"请登录"超链接
(2)localStroage
H5新特性---Web Worker---Web Stroage的更多相关文章
- H5新特性---SVG--椭圆--直线--文本--滤镜(高斯滤镜--模糊)--地理定位
今天的目标 3.1:h5新特性--SVG--椭圆 <ellipse rx="" ry="" cx="" cy="" ...
- H5新特性汇总
H5新特性: 新增选择器 document.querySelector.document.querySelectorAll 拖拽释放(Drag and drop) API 媒体播放的 video 和 ...
- H5新特性--WebStorage--WebSocke
今天的目标 3.2:h5新特性--WebStorage localStorage 在客户端浏览器保存数据 永久保存 保存数据 localStorage [key] = value 保存数据 loca ...
- H5新特性——--第三方绘图工具库 echarts(canvas)---SVG绘图
今天学习的内容 3.1:h5新特性---第三方绘图工具库 echarts(canvas) 百度 echarts;d3;two.js;.... 3.2:h5新特性---SVG绘图 3.2:h5新特性-- ...
- H5新特性-视频,音频-Flash-canvas绘图
json格式 json - > AJAX json:数据格式,通常是以字符串形式表示 对象 {"name":"james","age" ...
- H5新特性实现对class的增删改
直接撸代码 全靠死记硬背 没什么技术点 HTML部分 <!DOCTYPE html> <html lang="en"> <head> <m ...
- Atitti html5 h5 新特性attilax总结
Atitti html5 h5 新特性attilax总结 Attilax觉得不错的新特性 3.语义Header和Footer (The Semantic Header and Footer) 8.占位 ...
- 使用h5新特性,轻松监听任何App自带返回键
1.前言 如今h5新特性.新标签.新规范等有很多,而且正在不断完善中,各大浏览器商对它们的支持,也是相当给力.作为前端程序员,我觉得我们还是有必要积极关注并勇敢地加以实践.接下来我将和各位分享一个特别 ...
- H5新特性之data-*
简单介绍:html5的data-*能够为标签添加一些自定义的属性和值,并且这种自定义的属性和值可以通过js来获取,十分的便捷 代码: //html<tr th:each="plan : ...
随机推荐
- JQ删除数组中的某个对象
---恢复内容开始--- var pros = []; 全局变量function doSearchSal(){ var param = {}; var searchSal=$.trim($(" ...
- 微信小程序海报生成功能
如果是H5页面的话给大家推荐一款不错的插件html2canvas,这个插件可以将html元素转为canvas并一键生成png图片,但是本文的重点是在小程序上如何实现生成图片的功能.因为小程序没有DOM ...
- UI设计篇·入门篇·简单动画的实现,透明动画/旋转动画/移动动画/缩放动画,混合动画效果的实现,为动画设置监听事件,自定义动画的方法
基本的动画构成共有四种:透明动画/旋转动画/移动动画/缩放动画. 配置动画的方式有两种,一种是直接使用代码来配置动画效果,另一种是使用xml文档配置动画效果 相比而言,用xml文档写出来的动画效果,写 ...
- Kafka运维填坑(转)
前提: 只针对Kafka 0.9.0.1版本; 说是运维,其实偏重于问题解决; 大部分解决方案都是google而来, 我只是作了次搬运工; 有些问题的解决方案未必一定是通用的, 若应用到线上请慎重; ...
- chinalife的经验
1.当<img src="">时,浏览器会有生成border,可以使用css选择器,img[src=""] {/*设置样式*/}: 2.jquery ...
- javaSE基础知识
JVM,JRE,JDK三者的简单总结 1.见名解释 Java虚拟机(JVM):Java virtual machine简称JVM:“virtual”中文意思“虚拟的”,“machine”中文意思“机器 ...
- COM接口调用,CreateDispatch失败的问题
有一个自动化处理Office文档的程序,原本运行的很好,基于效率和UI效果的问题,改成了多线程处理,编译没问题,一运行就报错找不到Office软件. 程序中产生错误的地方就是创建COM对象失败,以前好 ...
- CSS 图像左右对齐
左右对齐图像使用的技术是浮动div元素. float:left 左对齐 float:right右对齐 示例 <!DOCTYPE html> <html> <hea ...
- Linux 标准输入输出、错误输出、重定向标准输出
再来看看 >& 操作符: 重定向操作符 描述 > 将命令输出写入到文件或设备(如打印机),而不是命令提示符窗口或句柄. < 从文件而不是从键盘或句柄读入命令输入. >& ...
- Linux seq_printf输出内容不完整的问题
Linux seq_printf输出内容不完整的问题 写在前面的话:这是多年前在项目中遇到的问题,作为博客的开篇之作,有不足之处,请各位大侠斧正!谢谢! seq_file接口介绍 有许多种方法能够实现 ...