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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
งานประจำวันที่ 11 ตุลาคม 2561
โดย Ittichai_chupol พฤ 11 ต.ค. 2018 9:47 am บอร์ด M070 - อิทธิชัย ชูผล
1
5
พฤ 11 ต.ค. 2018 7:08 pm โดย Ittichai_chupol
งานประจำวันที่ 10 ตุลาคม 2561
โดย prakon พ 10 ต.ค. 2018 10:24 am บอร์ด MT24 - นายปกรณ์ วิริยะธนวิโรจน์
3
12
พฤ 11 ต.ค. 2018 10:15 am โดย prakon
B - ปรับ font เป็น Sukhumvit
โดย thatsawan พ 10 ต.ค. 2018 5:07 pm บอร์ด สิริกิตติรัตน์ - Tester
0
2
พ 10 ต.ค. 2018 5:07 pm โดย thatsawan
สิ่งที่ต้องทำก่อนไป Present โปรแกรมให้ลูกค้าดู
โดย tai14 พ 10 ต.ค. 2018 2:34 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
39
พ 10 ต.ค. 2018 2:34 pm โดย tai14
Bug ก็เหมือน ความรัก
โดย tai14 พ 10 ต.ค. 2018 2:11 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
1
55
พ 10 ต.ค. 2018 6:42 pm โดย บุคคลทั่วไป
Module top hits (โมดูล ท็อปส์ ฮิต) สำหรับแสดงสินค้าที่มีผู้เข้าชมมากที่สุด
โดย pprn พ 10 ต.ค. 2018 1:39 pm บอร์ด Joomla Extension Review
0
22
พ 10 ต.ค. 2018 1:39 pm โดย pprn
อัพเดท Joomla เวอร์ชั่น 3.8.13 ปรับปรุงเรื่องความปลอดภัยของระบบ 5 จุด
โดย tsukasaz พ 10 ต.ค. 2018 10:49 am บอร์ด PHP News
0
23
พ 10 ต.ค. 2018 10:49 am โดย tsukasaz
Module Filter (โมดูล ฟิลเตอร์) ตัวกรองสินค้าสำหรับค้นหาสินค้าที่ต้องการ
โดย pprn พ 10 ต.ค. 2018 10:47 am บอร์ด Joomla Extension Review
0
21
พ 10 ต.ค. 2018 10:47 am โดย pprn
งานประจำวันที่ 10 ตุลาคม 2561
โดย pprn พ 10 ต.ค. 2018 10:13 am บอร์ด MT25 - นางสาวปรียากมล รินนาศักดิ์
1
13
พ 10 ต.ค. 2018 7:19 pm โดย pprn
งานประจำวันที่ 10 ตุลาคม 2561
โดย tai14 พ 10 ต.ค. 2018 10:04 am บอร์ด MT26 - นางสาวอัครยุภา ยงยุทธ
1
7
พ 10 ต.ค. 2018 7:23 pm โดย tai14
งานประจำวันที่ 10 ตุลาคม 2561
โดย nice_13 พ 10 ต.ค. 2018 9:48 am บอร์ด M071 - พิชญ์สินี คงจร
1
5
พ 10 ต.ค. 2018 7:05 pm โดย nice_13
งานประจำวันที่ 10 ตุลาคม 2561
โดย Ittichai_chupol พ 10 ต.ค. 2018 9:41 am บอร์ด M070 - อิทธิชัย ชูผล
5
30
พฤ 11 ต.ค. 2018 9:45 am โดย Ittichai_chupol
งานประจำวันที่ 10 ตุลาคม 2561
โดย tatiya พ 10 ต.ค. 2018 9:18 am บอร์ด M065 - ตติยะ นาชัย
1
4
พ 10 ต.ค. 2018 10:58 pm โดย tatiya
บันทึกการประชุม - ThaiVI
โดย mindphp พ 10 ต.ค. 2018 3:52 am บอร์ด ThaiVI (Main)
0
3
พ 10 ต.ค. 2018 3:52 am โดย mindphp
อัพเดทความคืบหน้า / Progress - ThaiVI
โดย mindphp พ 10 ต.ค. 2018 3:49 am บอร์ด ThaiVI (Main)
0
1
พ 10 ต.ค. 2018 3:49 am โดย mindphp
G - ข้อมูลสำหรับทำระบบ สรุปความต้องการ- ThaiVI
โดย mindphp พ 10 ต.ค. 2018 3:29 am บอร์ด ThaiVI (Main)
1
7
จ 15 ต.ค. 2018 3:13 am โดย mindphp
Module Products "tags name" (โมดูล โปรดักส์ "แท็กส์ เนมส์") สำหรับแสดงแท็กชื่อสินค้า
โดย pprn พ 10 ต.ค. 2018 12:37 am บอร์ด Joomla Extension Review
0
19
พ 10 ต.ค. 2018 12:37 am โดย pprn
การทำขนม หม้อแกง
โดย Ittichai_chupol อ 09 ต.ค. 2018 7:13 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
1
29
อ 09 ต.ค. 2018 10:29 pm โดย Pichet Seen Thawee
Review Module JoomShopping Free
โดย pprn อ 09 ต.ค. 2018 7:11 pm บอร์ด MT25 - นางสาวปรียากมล รินนาศักดิ์
0
7
อ 09 ต.ค. 2018 7:11 pm โดย pprn
Q - วิธีการเขียนโคด เพื่อให้ phpbb สร้าง คอลลัมใน ฐานข้อมูล โดยไม่ต้องไปสร้างในฐานข้อมูล
โดย Ittichai_chupol อ 09 ต.ค. 2018 7:09 pm บอร์ด Programming - PHP
3
46
พ 10 ต.ค. 2018 4:06 pm โดย thatsawan