利用html5的websocket实现websocket聊天室

2019-01-28 17:54:46王振洲

创建websocket
 
复制代码

ws=new WebSocket(address); //ws://127.0.0.1:8080

 
调用其构造函数,传入地址,就可以创建一个websocket了,值得注意的是地址协议得是ws/wss
 
关闭socket

复制代码

ws.close();

 
调用webservice实例的close()方法就可以关闭webservice,当然也可以传入一个code和string说明为什么关了
 
几个回调函数句柄
 
由于其异步执行,回调函数自然少不了,有四个重要的
 
onopen:连接创建后调用
onmessage:接收到服务器消息后调用
onerror:出错时调用
onclose:关闭连接的时候调用

看名字就知道是干什么的了,每个回调函数都会传入一个Event对象,可以通过event.data访问消息
 
使用API
 
我们可以在创建socket成功后为其回调函数赋值
 

复制代码

ws=new WebSocket(address);
ws.onopen=function(e){
var msg=document.createElement('div');
msg.style.color='#0f0';
msg.innerHTML="Server > connection open.";
msgContainer.appendChild(msg);
ws.send('{<'+document.getElementById('name').value+'>}');

 也可以通过事件绑定的方式

复制代码

ws=new WebSocket(address);
ws.addEventListener('open',function(e){
var msg=document.createElement('div');
msg.style.color='#0f0';
msg.innerHTML="Server > connection open.";
msgContainer.appendChild(msg);
ws.send('{<'+document.getElementById('name').value+'>}');

客户端实现
其实客户端的实现比较简单,除了websocket相关的几句就是一些自动focus、回车键事件处理、消息框自动定位到底部等简单功能,不一一说明了