一、html5新特性  websocket(重点)--多对多聊天室

HTTP:超文本传输协议

HTTP作用:传输网页中资源(html;css;js;image;video;..)

HTTP是浏览器搬运工

HTTP 工作方式:请示与响应

浏览器发服务器信息(请求数据)

服务器发数据给浏览器(响应消息)

#一次请求对应一次响应,如果没有请求就没有响应

#金融行业(股票/期货/汇率/...)  多长时间请求一次

新解决方案方式:新协议 websocket

websocket工作方式:广播和收听

适用范围:金融;弹幕;聊天室;客服

二、html5新特性  websocket(重点)--使用

服务器端:node.js  scoket.io 最方便最简单

客户端:浏览器原生对象 websocket功能较少

第三方:socket.io

#socket.io 多对多聊天室

#服务器端  下载第三方模块  (socket.io) 02_socketapp.js

npm i socket.io

#客户端    下载第三方模块  (socket.io) 02_socket.html

https://cdnjs.cloudflare.com/ajax/libs/socket.io/2.0.3/socket.io.js

#服务器端程序

(1)创建web 服务器

var app = require("http").createServer();

(2)创建socketio 服务器端对象

var io = require("socket.io")(app)

(3)监听端口

app.listen(3000);

(4)为io对象绑定事件 connection (当客户连接服务器触发此事件)

io.on("connection",(socket)=>{

#console.log("有客户端连接服务器....");

#socket 为当前客户创建专属服务员...

})

#客户端程序

(1)创建socket对象并且连接服务器

var clientSocket = io("ws://127.0.0.1:3000");

#ws: websocket

#127.0.0.1 服务器端程序所有机器地址

#3000     服务器运行端口号

#==========================================

#客户端发送数据给服务器 (一对一)

#socket.io 发送与接收数据采用方式事件绑定与事件触发机制

服务器(收)

socket.on("message",(data)=>{console.log(data);})

客户端(发)

clientSocket.emit("message","初始见面多关照");

#emit:触发指定事件

#==========================================

#服务器发送数据给客户端(一对一)

客户端(收)

clientSocket.on("server",(data)=>{})

服务器(发)

socket.emit("server","发送消息");

#==========================================

#广播消息:服务器向所有客户发送消息

客户端(收)

clientSocket.on("list",(data)=>{})

服务器(发)

io.emit("list","明天开始大降价");

#==========================================

服务器端默认事件:disconnect

#当客户端关闭浏览器默认触发事件(客户端离开了)

三、html5新特性  websocket(重点)--多对多聊天室

server/03_chart_app.js

client/03_chart.html

四、html5 新特性  webStroage

解决问题:在客户端浏览器中保存用户专用数据

作用:登录用户昵称;购物车购物车;...

#注意事项:webStorage 客户端不要存储安全级别高数据

#安全级别高数据 用户密码;uid

客户端存储方式

服务器端存储方式

(不安全;数据量很少)

(安全/海量/高速查询)

(1)cookie

优点:兼容性好

缺点:操作复杂;1kb

(1)数据库

(2)Flash

缺点:依赖flash播放器

(2)session 对象(数据量少)

(3)WebStorage

优点:操作简单;8MB

缺点:兼容性

(3)文件   data.txt

(4)IndexDB 不标准

(4)内存数据库,文档数据库

WebStorage 存储数据依赖二个对象

#sessionStorage

sessionStorage对象存储范围在当前会话中.当前会话中所有网页

都可以使用sessionStorage 保存,但是如果会话结束数据丢失!

注意事项:会话结束(关闭浏览器-关闭标签),退出浏览器生效

#localStorage

此对象保存数据永久保存

WebStorage 操作数据方法与属性以上两个对象通用

(1)保存数据      setItem(key,value);  #key键  value 值

(2)获取数据      var value = getItem(key);

(3)删除指定数据  removeItem(key);

(4)清空所有数据  clear()

(5)数据长度      length

HTML5新特性 websocket(重点)--多对多聊天室的更多相关文章

  1. HTML5新特性--svg-echarts(重点)-拖动API-WebWorker

    一.html5新特性--svg--(折线/渐变特效对象/滤镜) #折线:多个坐标点组件一条折线 <polyline points="50,50 70,55 60,66 " s ...

  2. HTML5新特性-- -定时器

    一.定时器:一次性定时器/周期性定时器 #requestAnimationFrame 智能定时器 #此定时器主要使用范围:动画和游戏中 特点: setTimeout(fn,500); setInter ...

  3. html5新特性

    这一篇博文不会告诉你怎么去使用html5的新特性,只会给你总结一下新特性------对于好学的人可以把这篇文章当做一个目录 对于初接触的人来说是一个导向 对于已经接触过的人来说是一个检测你掌握程度的检 ...

  4. html5新特性与用法大全了解一下

    有好多小伙伴私聊我问我html5新特性 和用法,下面我给大家具体介绍一下html5都新加了哪些新特性,下面我给大家总结一下. 1)新的语义标签 footer header 等等2)增强型表单 表单2. ...

  5. 前端进阶系列(三):HTML5新特性

    HTML5 是对 HTML 标准的第五次修订.其主要的目标是将互联网语义化,以便更好地被人类和机器阅读,并同时提供更好地支持各种媒体的嵌入.HTML5 的语法是向后兼容的.现在国内普遍说的 H5 是包 ...

  6. 转: HTML5新特性之Mutation Observer

    转: HTML5新特性之Mutation Observer Mutation Observer是什么 Mutation Observer(变动观察器)是监视DOM变动的接口.当DOM对象树发生任何变动 ...

  7. HTML5新特性之CSS+HTML5实例

    1.新的DOCTYPE和字符集 HTML5的一项准则就是化繁为简,Web页面的DOCTYPE被极大的简化. <!DOCTYPE html> 同时字符集声明也被简化了: <meta c ...

  8. HTML5新特性:FileReader 和 FormData

    连接在这里: HTML5新特性:FileReader 和 FormData

  9. web全栈架构师[笔记] — 03 html5新特性

    HTML5新特性 一.geolocation PC端 精度比较低 通过IP库定位 移动端 通过GPS window.navigator.geolocation 单次 getCurrentPositio ...

随机推荐

  1. IntelliJ IDEA在mac中完全删除方法

    cd /Applications/ rm -r IntelliJ\ IDEA.app/ rm -r /Users/apple/Library/Logs/IntelliJIdea2019.3/ rm - ...

  2. 详解PHP中instanceof关键字及instanceof关键字有什么作用

    来源:https://www.jb51.net/article/74409.htm PHP5的另一个新成员是instdnceof关键字.使用这个关键字可以确定一个对象是类的实例.类的子类,还是实现了某 ...

  3. java中Runnable和Callable的区别

    文章目录 运行机制 返回值的不同 Exception处理 java中Runnable和Callable的区别 在java的多线程开发中Runnable一直以来都是多线程的核心,而Callable是ja ...

  4. 蘑菇街CEO陈琪上市致辞:科技是生产力 美丽也是生产力

    雷帝网 乐天 12月7日报道 蘑菇街CEO陈琪今日在纽交所上市致辞时表示,蘑菇街的使命是让时尚触手可及,立志成为最领先的时尚目的地,并把"科技是生产力,美丽也是生产力"作为蘑菇街价 ...

  5. C++编程入门--No.6

    题目:用*号输出字母C的图案. 程序分析:可先用'*'号在纸上写出字母C,再分行输出. #include <bits/stdc++.h> using namespace std; int ...

  6. 数学--数论---P4718 Pollard-Rho算法 大数分解

    P4718 [模板]Pollard-Rho算法 题目描述 MillerRabin算法是一种高效的质数判断方法.虽然是一种不确定的质数判断法,但是在选择多种底数的情况下,正确率是可以接受的.Pollar ...

  7. Java模拟UDP通信

    目录 Java基础:模拟UDP通信 1.一次发送,一次接收 1.1.发送方 1.2.接收方 2.多次发送,多次接收 2.1.发送方 2.2.接收方 3.模拟双方通信 3.1.发送方的线程 3.2.接收 ...

  8. Spring官网阅读 | 总结篇

    接近用了4个多月的时间,完成了整个<Spring官网阅读>系列的文章,本文主要对本系列所有的文章做一个总结,同时也将所有的目录汇总成一篇文章方便各位读者来阅读. 下面这张图是我整个的写作大 ...

  9. 动态代理学习(二)JDK动态代理源码分析

    上篇文章我们学习了如何自己实现一个动态代理,这篇文章我们从源码角度来分析下JDK的动态代理 先看一个Demo: public class MyInvocationHandler implements ...

  10. Maxim实时时钟芯片设计指南5791-关于编写健壮的实时时钟控制代码的提示

    用DS12C887设计一个万年历,虽然反复查看说明书,还是出各种的错误. 因此,从美信官网查询资料,翻译的不太通,凑合着对照看. 原文链接 Tips for Writing Bulletproof R ...