ให้เรตสมาชิก: 3 / 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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
B - รายงานภาษี วันที่ตกบรรทัด
โดย taemmynatchapon อ 10 ก.ค. 2018 3:12 pm บอร์ด M.D.Soft Co.,Ltd. - Tester
1
6
พ 11 ก.ค. 2018 6:10 pm โดย thatsawan
Tip CSS : Navigation Tabs (เนวิเกชั่น แท็บส์) อย่างง่าย
โดย pprn อ 10 ก.ค. 2018 2:43 pm บอร์ด CSS Knowledge
0
14
อ 10 ก.ค. 2018 2:43 pm โดย pprn
วิธีเดินทางจาก ร้อยเอ็ด มากรุงเทพ
โดย tatiya อ 10 ก.ค. 2018 11:19 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
36
อ 10 ก.ค. 2018 11:19 am โดย tatiya
Tip CSS : Sidebar Navigation with Input and Buttons (สไลด์บาร์ เนวิเกชั่น กับช่องค้นหา) สีดำอย่างง่าย
โดย pprn อ 10 ก.ค. 2018 11:00 am บอร์ด CSS Knowledge
0
20
อ 10 ก.ค. 2018 11:00 am โดย pprn
งานประจำวันที่ 10 กรกฏาคม 2561
โดย pprn อ 10 ก.ค. 2018 10:22 am บอร์ด MT25 - นางสาวปรียากมล รินนาศักดิ์
1
33
อ 10 ก.ค. 2018 10:44 am โดย pprn
งานประจำวันที่ 10 กรกฎาคม 2561
โดย prakon อ 10 ก.ค. 2018 10:12 am บอร์ด MT24 - นายปกรณ์ วิริยะธนวิโรจน์
1
29
อ 10 ก.ค. 2018 1:32 pm โดย prakon
งานประจำวันที่ 10 กรกฎาคม 2018
โดย tatiya อ 10 ก.ค. 2018 9:52 am บอร์ด M065 - ตติยะ นาชัย
3
42
พ 11 ก.ค. 2018 9:46 am โดย tatiya
การใช้งาน gitlab ร่วมกับ netbean เบื้องต้น
โดย prakon จ 09 ก.ค. 2018 6:26 pm บอร์ด Python Knowledge
0
106
จ 09 ก.ค. 2018 6:26 pm โดย prakon
R - tool_PMT (Payment) คำนวณหาจำนวนเงินที่จะต้องจ่ายในแต่ละงวด
โดย pprn จ 09 ก.ค. 2018 6:22 pm บอร์ด MT25 - นางสาวปรียากมล รินนาศักดิ์
2
44
อ 10 ก.ค. 2018 10:31 am โดย pprn
[ปัญหา การติดตั้ง Netbeans]
โดย tatiya จ 09 ก.ค. 2018 5:36 pm บอร์ด Programming - C/C++ & java & Python
0
20
จ 09 ก.ค. 2018 5:36 pm โดย tatiya
Tip CSS : Sidebar Dropdown Navigation (ซีเอสเอส สไลด์บาร์ ดรอปดาว์น เนวิเกชั่น) สีดำอย่างง่าย
โดย pprn จ 09 ก.ค. 2018 3:00 pm บอร์ด CSS Knowledge
0
26
จ 09 ก.ค. 2018 3:00 pm โดย pprn
Tip CSS : Sidebar Navigation (ซีเอสเอส สไลด์บาร์ เนวิเกชั่น) สีดำอย่างง่าย
โดย pprn จ 09 ก.ค. 2018 1:34 pm บอร์ด CSS Knowledge
0
18
จ 09 ก.ค. 2018 1:34 pm โดย pprn
การสร้างระบบ Login (ล็อคอิน) และ logout (ล็อคเอ้าท์) อย่างง่าย
โดย pprn จ 09 ก.ค. 2018 11:29 am บอร์ด PHP Knowledge
0
33
จ 09 ก.ค. 2018 11:29 am โดย pprn
MyNote
โดย tatiya จ 09 ก.ค. 2018 10:58 am บอร์ด M065 - ตติยะ นาชัย
4
71
ส 14 ก.ค. 2018 7:30 pm โดย tatiya
Work's no hand ตติยะ นาชัย m066
โดย tatiya จ 09 ก.ค. 2018 10:46 am บอร์ด M065 - ตติยะ นาชัย
0
10
จ 09 ก.ค. 2018 10:46 am โดย tatiya
งานประจำวันที่ 9 กรกฏาคม 2018
โดย tatiya จ 09 ก.ค. 2018 10:36 am บอร์ด M065 - ตติยะ นาชัย
2
51
จ 09 ก.ค. 2018 2:03 pm โดย AePongsak
งานประจำวันที่ 9 กรกฏาคม 256
โดย prakon จ 09 ก.ค. 2018 10:16 am บอร์ด MT24 - นายปกรณ์ วิริยะธนวิโรจน์
1
13
จ 09 ก.ค. 2018 7:29 pm โดย prakon
การรับค่าตัวเลขจากฟอร์ม (Form) แบบ GET (เก็ท) ให้แสดงผลลัพธ์เป็นตัวหารร่วมมาก (ห.ร.ม.)
โดย pprn จ 09 ก.ค. 2018 10:01 am บอร์ด PHP Knowledge
0
18
จ 09 ก.ค. 2018 10:01 am โดย pprn
การรับค่าตัวเลขจากฟอร์ม (Form) แบบ GET (เก็ท) ให้แสดงผลลัพธ์เป็นตัวคูณร่วมน้อย (ค.ร.น)
โดย pprn จ 09 ก.ค. 2018 9:58 am บอร์ด PHP Knowledge
0
11
จ 09 ก.ค. 2018 9:58 am โดย pprn
การรับค่าตัวเลขจากฟอร์ม (Form) ให้แสดงสูตรคูณ โดยผลลัพธ์แสดงสลับสีแต่ละบรรทัด
โดย pprn จ 09 ก.ค. 2018 9:52 am บอร์ด PHP Knowledge
0
19
จ 09 ก.ค. 2018 9:52 am โดย pprn