合规国际互联网加速 OSASE为企业客户提供高速稳定SD-WAN国际加速解决方案。 广告
## **WebSocket 客户端** 在客户端,没有必要为 WebSockets 使用 JavaScript 库。实现 WebSockets 的 Web 浏览器将通过 WebSockets 对象公开所有必需的客户端功能(主要指支持 Html5 的浏览器)。 ## **客户端 API** 以下 API 用于创建 WebSocket 对象。 var Socket = new WebSocket(url, [protocol] ); 以上代码中的第一个参数 url, 指定连接的 URL。第二个参数 protocol 是可选的,指定了可接受的子协议。 ### **WebSocket 属性** 以下是 WebSocket 对象的属性。假定我们使用了以上代码创建了 Socket 对象: 属性|描述 :---:|:--: Socket.readyState| 只读属性 readyState 表示连接状态,可以是以下值:0 - 表示连接尚未建立。1 - 表示连接已建立,可以进行通信。2 - 表示连接正在进行关闭。3 - 表示连接已经关闭或者连接不能打开。 Socket.bufferedAmount| 只读属性 bufferedAmount 已被 send() 放入正在队列中等待传输,但是还没有发出的 UTF-8 文本字节数。 ### **WebSocket 事件** 以下是 WebSocket 对象的相关事件。假定我们使用了以上代码创建了 Socket 对象: 事件|事件处理程序|描述 :---:|:--:|:--: open| Socket.onopen| 连接建立时触发 message| Socket.onmessage| 客户端接收服务端数据时触发 error| Socket.onerror| 通信发生错误时触发 close| Socket.onclose| 连接关闭时触发 ### **WebSocket 方法** 以下是 WebSocket 对象的相关方法。假定我们使用了以上代码创建了 Socket 对象: 方法|描述 :--:|:--: Socket.send()| 使用连接发送数据 Socket.close()| 关闭连接 示例 ``` // 初始化一个 WebSocket 对象 var ws = new WebSocket("ws://localhost:9998/echo"); // 建立 web socket 连接成功触发事件 ws.onopen = function () { // 使用 send() 方法发送数据 ws.send("发送数据"); alert("数据发送中..."); }; // 接收服务端数据时触发事件 ws.onmessage = function (evt) { var received_msg = evt.data; alert("数据已接收..."); }; // 断开 web socket 连接成功触发事件 ws.onclose = function () { alert("连接已关闭..."); }; ```