Javascript WebSocket使用實例介紹(簡明入門教程)

http://www.jb51.net/article/49060.htm

網絡套接字是下一代WEB應用程序雙向通信技術,它是基於一個獨立的socket並且需要客戶端瀏覽器支持HTML5
一旦你瞭解了網絡套接字與WEB服務器的連接,你將可以從瀏覽器發送數據到服務器並且可以接收由服務器返回的響應數據。

以下是創建一個新的WebSocket對象的API:

var Socket = new WebSocket(url, [protocal] );

這裏第一個參數是指要連接的URL,第二個參數是可選的,如果需要的話,則是指定一個的服務器支持的協議。

WEB Socket屬性:

屬性 說明
Socket.readyState readyState的代表的ReadOnly屬性的連接狀態。它可以有以下值:
  1. 一個0值表示該連接尚未建立。

  2. 值爲1表示連接建立和溝通是可能的。

  3. 值爲2表示連接是通過將結束握手。

  4. 值爲3表示連接已關閉或無法打開。

Socket.bufferedAmount 讀屬性的bufferedAmount代表文本的字節數,utf - 8的排隊使用send()方法。

WEB Socket事件:

事件 處理程序 說明
open Socket.onopen 此事件發生在套接字建立連接。
message Socket.onmessage 此事件發生時,客戶端收到來自服務器的數據。
error Socket.onerror 此事件發生時有任何通信錯誤。
close Socket.onclose 此事件發生在連接關閉。

WEB Socket方法:

方法 說明
Socket.send() send(data)方法用來連接傳輸數據。
Socket.close() close()方法將被用於終止任何現有的連接。


WEB Socket例子:



<!DOCTYPE HTML>
<html>
<head>
<script type="text/javascript">
function WebSocketTest()
{
  if ("WebSocket" in window)
  {
     alert("WebSocket is supported by your Browser!");
     // Let us open a web socket
     var ws = new WebSocket("ws://localhost:9998/echo");
     ws.onopen = function()
     {
        // Web Socket is connected, send data using send()
        ws.send("Message to send");
        alert("Message is sent...");
     };
     ws.onmessage = function (evt)
     {
        var received_msg = evt.data;
        alert("Message is received...");
     };
     ws.onclose = function()
     {
        // websocket is closed.
        alert("Connection is closed...");
     };
  }
  else
  {
     // The browser doesn't support WebSocket
     alert("WebSocket NOT supported by your Browser!");
  }
}
</script>
</head>
<body>
<div id="sse">
   <a href="javascript:WebSocketTest()">Run WebSocket</a>
</div>
</body>
</html>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章