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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
MOD_MTB_NEWS_RECENT
ช่วยหน่อยครับ phpmailer เมล์ไม่เข้า outlook ของบริษัท
โดย Kun Chakun พ 15 มี.ค. 2017 5:30 pm บอร์ด Programming - PHP
0
100
พ 15 มี.ค. 2017 5:30 pm โดย Kun Chakun
ทำยังไงให้ไฟล์ rml. เปิดกลับเข้ามาที่โปรแกรม OpenOffice ได้ค่ะ
โดย thatsawan พ 15 มี.ค. 2017 4:11 pm บอร์ด Programming - C/C++ & java & Python
0
28
พ 15 มี.ค. 2017 4:11 pm โดย thatsawan
select เลือกที่เป็นหัวข้อได้ ต้องทำอย่างไรคะ
โดย gainkullan พ 15 มี.ค. 2017 3:31 pm บอร์ด Programming - PHP
0
149
พ 15 มี.ค. 2017 3:31 pm โดย gainkullan
แก้ปัญหาเข้า ssh ด้วย FileZilla แล้ว Error ssh_init: Host does not exist
โดย mindphp พ 15 มี.ค. 2017 2:32 am บอร์ด Linux - Web Server
1
49
พ 15 มี.ค. 2017 2:32 am โดย mindphp
FileZilla Client ออกเวอร์ชั่นใหม่ 3.25.0 (2017-03-13)
โดย mindphp พ 15 มี.ค. 2017 1:39 am บอร์ด PHP News
0
32
พ 15 มี.ค. 2017 1:39 am โดย mindphp
ลองเขียน Framework ทดสอบการเชื่อมต่อ Server แล้วเกิด Error แก้ไขยังไงครับ
โดย bom_002 อ 14 มี.ค. 2017 7:35 pm บอร์ด Programming - C/C++ & java & Python
2
51
อ 14 มี.ค. 2017 7:35 pm โดย bom_002
ช่วยด้วยค่ะหน้าแอดมินเว็บแก้ไขอะไรไม่ได้ The requested URL was not found on this server. Apache Server at / port80
โดย บุคคลทั่วไป อ 14 มี.ค. 2017 6:19 pm บอร์ด Joomla Development
1
69
อ 14 มี.ค. 2017 6:19 pm โดย บุคคลทั่วไป
การเคลื่อนที่หรือการเปลี่ยนตำแหน่งของวัตถุในช่วงเวลาหนึ่ง
โดย bom_002 อ 14 มี.ค. 2017 5:27 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
33
อ 14 มี.ค. 2017 5:27 pm โดย bom_002
ระบบมัลติโปรเซสเซอร์ Multiprocessor System(มัลติโปรเชสเชอ ชิสเต็ม)
โดย bom_002 อ 14 มี.ค. 2017 4:36 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
31
อ 14 มี.ค. 2017 4:36 pm โดย bom_002
ขอวิธีนำ url มาเรียกใช้ในไฟล์ค่ะ
โดย moomai อ 14 มี.ค. 2017 3:30 pm บอร์ด Programming - PHP
0
50
อ 14 มี.ค. 2017 3:30 pm โดย moomai
สอบถามค่ะ จะแปลงค่า xml เก็บข้อมูลยังไงค่ะ
โดย moomai อ 14 มี.ค. 2017 3:17 pm บอร์ด Programming - PHP
1
56
อ 14 มี.ค. 2017 3:17 pm โดย tsukasaz
ถอด xml ใน php ยังไงคะ
โดย moomai อ 14 มี.ค. 2017 2:38 pm บอร์ด Programming - PHP
4
69
อ 14 มี.ค. 2017 2:38 pm โดย moomai
แนะนำบอร์ดไมโครคอนโทรเลอร์ Arduino(อาดุยโน่)
โดย bom_002 อ 14 มี.ค. 2017 12:06 pm บอร์ด Microsoft Office Knowledge & line & Etc
1
56
อ 14 มี.ค. 2017 12:06 pm โดย arduino
โครงสร้างการเขียนโปรแกรม
โดย bom_002 จ 13 มี.ค. 2017 10:14 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
376
จ 13 มี.ค. 2017 10:14 pm โดย bom_002
computer graphics (คอมพิวเตอร์กราฟิก)และซอฟต์แวร์ทางกราฟิก
โดย bom_002 อ 12 มี.ค. 2017 12:22 am บอร์ด Microsoft Office Knowledge & line & Etc
0
46
อ 12 มี.ค. 2017 12:22 am โดย bom_002
การใช้งานคำสั่งต่าง ๆ บน UNIX สำหรับผู้เริ่มต้นศึกษา
โดย bom_002 ส 11 มี.ค. 2017 7:23 pm บอร์ด Linux - Web Server
4
141
ส 11 มี.ค. 2017 7:23 pm โดย thatsawan
สารกึ่งตัวนํา Bipolar Junction Transistor (ไบโพลา จักชัน ทรานซิสเตอร์)
โดย bom_002 ส 11 มี.ค. 2017 6:00 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
53
ส 11 มี.ค. 2017 6:00 pm โดย bom_002
อาหารหลัก 5 หมู่ มีอะไรบ้างและมีประโยชน์อย่างไร
โดย bom_002 ศ 10 มี.ค. 2017 6:38 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
48
ศ 10 มี.ค. 2017 6:38 pm โดย bom_002
VDSL(วีดีเอสแอล) กับ ADSL(เอดีเอสแอล) ต่างกันอย่างไร
โดย bom_002 ศ 10 มี.ค. 2017 4:22 pm บอร์ด Microsoft Office Knowledge & line & Etc
1
71
ศ 10 มี.ค. 2017 4:22 pm โดย mindphp
ฮาร์ดแวร์สำหรับเครือข่าย (Network hardware)
โดย bom_002 ศ 10 มี.ค. 2017 2:42 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
97
ศ 10 มี.ค. 2017 2:42 pm โดย bom_002