HTML5新特性 websocket(重点)--多对多聊天室
一、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(重点)--多对多聊天室的更多相关文章
- HTML5新特性--svg-echarts(重点)-拖动API-WebWorker
一.html5新特性--svg--(折线/渐变特效对象/滤镜) #折线:多个坐标点组件一条折线 <polyline points="50,50 70,55 60,66 " s ...
- HTML5新特性-- -定时器
一.定时器:一次性定时器/周期性定时器 #requestAnimationFrame 智能定时器 #此定时器主要使用范围:动画和游戏中 特点: setTimeout(fn,500); setInter ...
- html5新特性
这一篇博文不会告诉你怎么去使用html5的新特性,只会给你总结一下新特性------对于好学的人可以把这篇文章当做一个目录 对于初接触的人来说是一个导向 对于已经接触过的人来说是一个检测你掌握程度的检 ...
- html5新特性与用法大全了解一下
有好多小伙伴私聊我问我html5新特性 和用法,下面我给大家具体介绍一下html5都新加了哪些新特性,下面我给大家总结一下. 1)新的语义标签 footer header 等等2)增强型表单 表单2. ...
- 前端进阶系列(三):HTML5新特性
HTML5 是对 HTML 标准的第五次修订.其主要的目标是将互联网语义化,以便更好地被人类和机器阅读,并同时提供更好地支持各种媒体的嵌入.HTML5 的语法是向后兼容的.现在国内普遍说的 H5 是包 ...
- 转: HTML5新特性之Mutation Observer
转: HTML5新特性之Mutation Observer Mutation Observer是什么 Mutation Observer(变动观察器)是监视DOM变动的接口.当DOM对象树发生任何变动 ...
- HTML5新特性之CSS+HTML5实例
1.新的DOCTYPE和字符集 HTML5的一项准则就是化繁为简,Web页面的DOCTYPE被极大的简化. <!DOCTYPE html> 同时字符集声明也被简化了: <meta c ...
- HTML5新特性:FileReader 和 FormData
连接在这里: HTML5新特性:FileReader 和 FormData
- web全栈架构师[笔记] — 03 html5新特性
HTML5新特性 一.geolocation PC端 精度比较低 通过IP库定位 移动端 通过GPS window.navigator.geolocation 单次 getCurrentPositio ...
随机推荐
- udp协议与tcp协议
TCP协议与UDP协议支持的应用协议 TCP支持的应用协议主要有:Telnet.FTP.SMTP等: UDP支持的应用层协议主要有:NFS(网络文件系统).SNMP(简单网络管理协议).DNS(主域名 ...
- Spring Boot的exit code
文章目录 Spring Boot的exit code 自定义Exit Codes ExitCodeGenerator ExitCodeExceptionMapper ExitCodeEvent Spr ...
- 基于jenkins自动打包并部署Tomcat环境
传统网站部署的流程 在运维过程中,网站部署是运维的工作之一.传统的网站部署的流程大致分为:需求分析->原型设计->开发代码->提交代码->内网部署->内网测试->确 ...
- material UI中withStyles和makeStyles的区别
在material UI中,withStyles和makeStyles是经常使用的两个用于封装样式的函数.对于刚使用material UI的开发者而言,可能不太清楚这两者的区别. 本文简要探究 ...
- Muduo网络库实战(一):安装和配置
1. 参考资料 <Muduo_网络库使用手册> 2. 实战记录 1) muduo依赖项安装 centos安装cmake命令:# yum install cmake centos安装libb ...
- CodeForces-259B]Little Elephant and Magic Square
Little Elephant loves magic squares very much. A magic square is a 3 × 3 table, each cell contains ...
- alerta 集中化告警信息 -zabbix
Docker安装Alerta https://hub.docker.com/D/alerta/alerta-web/ How to use this image To use this image ...
- django最全面的知识点,直接开发完整手机购物商城练手,
带手机验证码登陆, 带全套购物车系统 带数据库 前后端分离开发 带定位用户功能 数据库代码为本地制作好了 带支付宝支付系统 带django开发服务器接口教程 地址: https://www.duans ...
- 在Vue中使用iview的Select控件实现一个多级选项列表
前言 今天项目要实现一个多级选项列表,发现iview官网上没有写这个例子,于是自己就实现了,如果对你有帮助请点个赞 ‘ * ’!! 解决方法:下面我们就来使用V-for 来定义一个二级选项列表 ,代码 ...
- 软件——Jira是什么
JIRA这个工具接触有好几年了,在多个海外项目上都用过这个工具.去年又在项目上深度使用后就有点爱不释手了,回国后也在找机会推荐给其它项目上用.最近正好有新项目需要用,借这个机会把JIRA的配置学习的过 ...