ให้เรตสมาชิก: 4 / 5

ดาวใช้งานดาวใช้งานดาวใช้งานดาวใช้งานดาวไม่ได้ใช้งาน
 
Websocket ใน HTML 5 เทคโนโลยี ติดต่อเร็ว กว่า Ajax ไม่ต้องรีเฟรชหน้า
Websocket ใน HTML 5 เทคโนโลยี ติดต่อเร็ว กว่า Ajax ไม่ต้องรีเฟรชหน้า

Websocket คือ ถ้าจะอธิบายให้สั้นๆ และได้ใจความ Websocket เป็นเทคโนโลยีเพื่อใช้ การติดต่อสือสารระหว่าง Web server กับ Client แบบ Real Time Client ที่เป็น html5 + Javascript สามารถรับข้อมูลทางผั่ง Server มาแสดงผลได้ ผ่าน Protocol TCP/IP โดยไม่ต้อง Refresh หน้า เช่นเดียวกับ Ajax แต่ Websocket นั้นมีข้อดีกว่า Ajax คือ Websocket ไม่ต้องส่ง Request ใหม่ เพื่อส่งคำรองขอไปยัง server และ รอรับ respond จากทางฝั่ง Server ทำให้ Websocket ประหยัดทั้งเวลา และปริมาณข้อมูลที่ส่งไปมาระหว่าง web server กับ Client โดยการทำงานของ Websocket มันจะรอรับ Message ทางฝั่ง web server อยู่ตลอดเวลา หลังจากที่ได้ส่งคำสั่ง ติดต่อ Websocket Server ไปแล้วในครั้งแรก และมันจะรอรับ Message จนกระทั้งจะสั่ง Close หรือหยุดการติดต่
ลองดูตัวอย่างโค้ด HTML + Websocket

<!DOCTYPE html>

<meta charset="utf-8" />

<title>WebSocket Test By Mindphp.com</title>

<script language="javascript" type="text/javascript">

  var wsUri = "ws://echo.websocket.org/";
  var output;

  function init()
  {
    output = document.getElementById("output");
    testWebSocket();
  }

  function testWebSocket()
  {
    websocket = new WebSocket(wsUri);
    websocket.onopen = function(evt) { onOpen(evt) };
    websocket.onclose = function(evt) { onClose(evt) };
    websocket.onmessage = function(evt) { onMessage(evt) };
    websocket.onerror = function(evt) { onError(evt) };
  }

  function onOpen(evt)
  {
    writeToScreen("CONNECTED");
    doSend("WebSocket rocks");
  }

  function onClose(evt)
  {
    writeToScreen("DISCONNECTED");
  }

  function onMessage(evt)
  {
      alert(evt);
    writeToScreen('<span style="color: blue;">RESPONSE: ' + evt.data+'</span>');
    websocket.close();
  }

  function onError(evt)
  {
    writeToScreen('<span style="color: red;">ERROR:</span> ' + evt.data);
  }

  function doSend(message)
  {
    writeToScreen("SENT: " + message); 
    websocket.send(message);
  }

  function writeToScreen(message)
  {
    var pre = document.createElement("p");
    pre.style.wordWrap = "break-word";
    pre.innerHTML = message;
    output.appendChild(pre);
  }

  window.addEventListener("load", init, false);

</script>

<h2>WebSocket Test</h2>
<input id="text" name="text" type="text" size="36">
<label>
<input type="submit" name="button" id="button" value=" Send " onClick=" doSend(document.getElementById('text').value);">
</label>
<div id="output"></div>

</html> 

เรียกน้ำย่อยวันนี้แค่นี้ก่อน วันหลังจะเอาความรู้เรื่อง เทคโนโลยี ตัวนี้มาลงอีกครับ พูดคุยกันได้ที่เว็บบอร์ด Pogramming - PHP

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
อัพโหลดรูปขึ้น media แล้วไม่ขึ้นครับ
โดย Kumpee Shooshuenmanakij พ 07 มี.ค. 2018 1:16 pm บอร์ด Joomla Development
1
130
พ 07 มี.ค. 2018 3:36 pm โดย tsukasaz
การใช้งาน Python GUI (Tkinter) : การเรียกใช้ Font
โดย Jom07 อ 06 มี.ค. 2018 4:33 pm บอร์ด Python Knowledge
0
117
อ 06 มี.ค. 2018 4:33 pm โดย Jom07
การใช้งาน Python GUI (Tkinter) : การเรียกใช้ from ใน python 2 และ python 3
โดย Jom07 อ 06 มี.ค. 2018 3:18 pm บอร์ด Python Knowledge
0
146
อ 06 มี.ค. 2018 3:18 pm โดย Jom07
เมื่อโปรแกรมเมอร์เข้าครัว
โดย Before Dong อ 06 มี.ค. 2018 10:19 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
245
อ 06 มี.ค. 2018 10:19 am โดย Before Dong
Q :ต้องการอัพไฟล์ขึ้น git แต่ไม่สามารถเอาขึ้นได้
โดย Parichat จ 05 มี.ค. 2018 11:09 pm บอร์ด Joomla Development
8
226
อ 06 มี.ค. 2018 3:27 pm โดย Parichat
วิธีการ zip ไฟล์ Component เพื่อสามารถนำไปติดตั้งใน Joomla ตัวอื่นได้
โดย Parichat จ 05 มี.ค. 2018 7:53 pm บอร์ด Joomla Developing Knowledge
0
93
จ 05 มี.ค. 2018 7:53 pm โดย Parichat
การใช้งาน Python GUI (Tkinter) : Scrollbar Widget (วิดเจ็ตสเปรดชีต)
โดย Jom07 จ 05 มี.ค. 2018 6:17 pm บอร์ด Python Knowledge
0
107
จ 05 มี.ค. 2018 6:17 pm โดย Jom07
การใช้งาน Python GUI (Tkinter) : Spinbox (การทำสปินบ๊อก)
โดย Jom07 จ 05 มี.ค. 2018 4:32 pm บอร์ด Python Knowledge
0
112
จ 05 มี.ค. 2018 4:32 pm โดย Jom07
ตั้ง ค่า GitLab ส่งเมลออกด้วย SMTP
โดย mindphp จ 05 มี.ค. 2018 2:52 pm บอร์ด Linux - Web Server
10
167
จ 05 มี.ค. 2018 3:02 pm โดย mindphp
ปัญหา keyboard กด ไม่ได้
โดย mindphp จ 05 มี.ค. 2018 10:41 am บอร์ด ถาม - ตอบ คอมพิวเตอร์
0
91
จ 05 มี.ค. 2018 10:41 am โดย mindphp
ช้า ช้ามาก ช้าที่สุด
โดย Before Dong จ 05 มี.ค. 2018 10:39 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
94
จ 05 มี.ค. 2018 10:39 am โดย Before Dong
ทำ Auto Backup GitLab ข้าม Server และ กำหนดให้เก็บไฟล์ไว้ตามระยะเวลาที่ต้องการ
โดย mindphp อ 04 มี.ค. 2018 3:29 am บอร์ด Linux - Web Server
1
96
อ 04 มี.ค. 2018 3:34 am โดย mindphp
วิธีสร้าง ssh key บน freebsd , Ubuntu, Linux
โดย mindphp อ 04 มี.ค. 2018 2:55 am บอร์ด Linux - Web Server
0
87
อ 04 มี.ค. 2018 2:55 am โดย mindphp
วิธี Backup Restore Gitlab remote Server ใช้ได้กับ OS เวอร์ชั่นต่างกัน
โดย mindphp ส 03 มี.ค. 2018 2:59 am บอร์ด Linux - Web Server
2
161
อ 04 มี.ค. 2018 3:39 am โดย mindphp
E: Sub-process /usr/bin/dpkg returned an error code (1
โดย mindphp ศ 02 มี.ค. 2018 11:36 pm บอร์ด Linux - Web Server
0
78
ศ 02 มี.ค. 2018 11:36 pm โดย mindphp
ทิป ในการติดตั้ง OS บน VM แบบเร่งด่วน โดยดาวน์โหลดไฟล์ OS .iso โดยตรง
โดย mindphp ศ 02 มี.ค. 2018 6:46 pm บอร์ด Linux - Web Server
1
119
ศ 02 มี.ค. 2018 6:50 pm โดย mindphp
รวมความรู้สำหรับ ทำ Git ใช้งานเอง ด้วย Gitlab
โดย mindphp ศ 02 มี.ค. 2018 6:37 pm บอร์ด Linux - Web Server
3
183
อ 06 มี.ค. 2018 5:34 pm โดย Parichat
ประกาศรับสัมครงานตำแหน่ง PHP Web Programmer จำนวน 2 ตำแหน่ง ด่วน!!
โดย Anonymous ศ 02 มี.ค. 2018 5:02 pm บอร์ด Programming - PHP
0
171
ศ 02 มี.ค. 2018 5:02 pm โดย บุคคลทั่วไป
ตกงาน อย่ากังวล ประกันสังคมพร้อมดูแล
โดย Anonymous ศ 02 มี.ค. 2018 11:11 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
91
ศ 02 มี.ค. 2018 11:11 am โดย บุคคลทั่วไป
การใช้งาน Python GUI (Tkinter) : Color Chooser Dialog (ตัวเลือกสี)
โดย Jom07 พฤ 01 มี.ค. 2018 5:07 pm บอร์ด Python Knowledge
0
121
พฤ 01 มี.ค. 2018 5:07 pm โดย Jom07