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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
การติดตั้ง Android studio บน Mac OS
โดย Four อ 09 ม.ค. 2018 1:27 pm บอร์ด Mobile Application Developing- Android, iOS
0
21
อ 09 ม.ค. 2018 1:27 pm โดย Four
การใช้งานระบบ Grid Layout Module(กริด เลเอ้าโมเดล) ของ CSS(ซีเอสเอส)
โดย Parichat อ 09 ม.ค. 2018 1:26 pm บอร์ด CSS Knowledge
0
26
อ 09 ม.ค. 2018 1:26 pm โดย Parichat
GPS Tracking คืออะไร
โดย Jom07 อ 09 ม.ค. 2018 1:23 pm บอร์ด IOT - Internet of things
0
27
อ 09 ม.ค. 2018 1:23 pm โดย Jom07
โครงสร้าง Json
โดย Four อ 09 ม.ค. 2018 1:22 pm บอร์ด XML Knowledge
0
30
อ 09 ม.ค. 2018 1:22 pm โดย Four
เมื่อจ้าง Sale มาทำงานแต่ไม่มีระบบให้ใช้ ล้อไอที
โดย Before Dong อ 09 ม.ค. 2018 10:56 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
114
อ 09 ม.ค. 2018 10:56 am โดย Before Dong
การใช้ Method stop() ใน Jquery
โดย Parichat อ 09 ม.ค. 2018 10:26 am บอร์ด Jquery & Ajax Knowledge
0
37
อ 09 ม.ค. 2018 10:26 am โดย Parichat
งานประจำวันที่ 9 มกราคม 2561
โดย Jom07 อ 09 ม.ค. 2018 9:50 am บอร์ด MT23 - สุพรรษา พูลตา
1
37
อ 09 ม.ค. 2018 1:24 pm โดย Jom07
งานประจำวันที่ 9 มกราคม 2561
โดย Four อ 09 ม.ค. 2018 9:48 am บอร์ด MT22 - อิษยา งามสอาด
1
37
อ 09 ม.ค. 2018 1:27 pm โดย Four
งานประจำวันที่ 9 มกราคม 2561
โดย Parichat อ 09 ม.ค. 2018 9:39 am บอร์ด MT21 - ปาริชาติ รัตโณภาส
1
44
อ 09 ม.ค. 2018 3:53 pm โดย Parichat
การทำ datatable(ดาต้าเทเบล) โดยใช้ bootstrap(บูตสแตบ)
โดย Parichat อ 09 ม.ค. 2018 12:32 am บอร์ด Booststap Knowledge
0
48
อ 09 ม.ค. 2018 12:32 am โดย Parichat
ajax(เอแจ็กซ์) คืออะไร
โดย Parichat อ 09 ม.ค. 2018 12:12 am บอร์ด Jquery & Ajax Knowledge
0
51
อ 09 ม.ค. 2018 12:12 am โดย Parichat
การเขียนฟังชั่นในการเรียกใช้คำสั่ง MySQL(มายเอสคิวแอล)
โดย Parichat จ 08 ม.ค. 2018 6:32 pm บอร์ด SQL Knowledge
0
30
จ 08 ม.ค. 2018 6:32 pm โดย Parichat
อุปกรณ์ที่ใช้ร่วมกับการนำทางด้วย GPS ประกอบด้วยอะไรบ้าง
โดย Jom07 จ 08 ม.ค. 2018 6:26 pm บอร์ด IOT - Internet of things
0
30
จ 08 ม.ค. 2018 6:26 pm โดย Jom07
GPS ทำงานอย่างไร
โดย Jom07 จ 08 ม.ค. 2018 6:25 pm บอร์ด IOT - Internet of things
0
29
จ 08 ม.ค. 2018 6:25 pm โดย Jom07
ใช้งาน JSON บน Android
โดย Four จ 08 ม.ค. 2018 6:24 pm บอร์ด Mobile Application Developing- Android, iOS
0
21
จ 08 ม.ค. 2018 6:24 pm โดย Four
JSON คืออะไร
โดย Four จ 08 ม.ค. 2018 6:22 pm บอร์ด XML Knowledge
0
43
จ 08 ม.ค. 2018 6:22 pm โดย Four
GPS คืออะไร
โดย Jom07 จ 08 ม.ค. 2018 6:21 pm บอร์ด IOT - Internet of things
0
29
จ 08 ม.ค. 2018 6:21 pm โดย Jom07
ข้อแตกแต่งระหว่าง JSON กับ XML
โดย Four จ 08 ม.ค. 2018 6:18 pm บอร์ด XML Knowledge
0
30
จ 08 ม.ค. 2018 6:18 pm โดย Four
Email Hosting มีดีอย่างไร
โดย kubarnaza จ 08 ม.ค. 2018 6:00 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
23
จ 08 ม.ค. 2018 6:00 pm โดย kubarnaza
การเดินทางจากจังหวัดพิษณุโลกสู่กรุงเทพฯ
โดย Four จ 08 ม.ค. 2018 5:43 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
33
จ 08 ม.ค. 2018 5:43 pm โดย Four