ให้เรตสมาชิก: 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
UPDATE ข้อมูลใน DB ผ่าน form ไม่ขึ้น error เเต่ข้อมูลไม่อัพเดตตามที่เเก้ไขค่ะ
โดย gainkullan ศ 10 มี.ค. 2017 10:38 am บอร์ด Programming - PHP
4
113
ศ 10 มี.ค. 2017 10:38 am โดย gainkullan
วิธีอัพเกรด joomla 1.5 เป็น joomla 3.1 ด้วย MJUpgrade
โดย moomai พฤ 09 มี.ค. 2017 7:55 pm บอร์ด Mindphp Videoman
0
57
พฤ 09 มี.ค. 2017 7:55 pm โดย moomai
R - fix bug state ตอนขายของ service ไม่เป็น Done
โดย jay_limm พฤ 09 มี.ค. 2017 7:01 pm บอร์ด อาร์ซีพี โกลบอล จำกัด
4
22
พฤ 09 มี.ค. 2017 7:01 pm โดย jay_limm
ความน่าจะเป็น Probability (พลอบาบิลิตี้) ของเหตุการณ์ที่เกิดขึ้น
โดย bom_002 พฤ 09 มี.ค. 2017 5:04 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
44
พฤ 09 มี.ค. 2017 5:04 pm โดย bom_002
ถามการเพิ่มข้อจำกัดของตาราง ในpostgreSQL ค่ะ
โดย dawthana พฤ 09 มี.ค. 2017 3:38 pm บอร์ด SQL - Database
0
33
พฤ 09 มี.ค. 2017 3:38 pm โดย dawthana
วัสดุวิศวกรรม Engineering Materials(เอนจิเนียริง แมททิเรียว)
โดย bom_002 พฤ 09 มี.ค. 2017 3:20 pm บอร์ด Share Knowledge
0
58
พฤ 09 มี.ค. 2017 3:20 pm โดย bom_002
สอบถามเปลี่ยนชื่อ Table ใน phpmyAdmin ครับ
โดย AePongsak พฤ 09 มี.ค. 2017 2:14 pm บอร์ด SQL - Database
1
62
พฤ 09 มี.ค. 2017 2:14 pm โดย thatsawan
สงสัยในการ # คอมเม้นต์ในภาษา python
โดย bom_002 พฤ 09 มี.ค. 2017 1:34 pm บอร์ด Programming - C/C++ & java & Python
3
63
พฤ 09 มี.ค. 2017 1:34 pm โดย Akk Chu
การสื่อสารข้อมูล (Data Communications) กระบวนการถ่ายโอนหรือแลกเปลี่ยนข้อมูล
โดย bom_002 พฤ 09 มี.ค. 2017 12:09 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
0
52
พฤ 09 มี.ค. 2017 12:09 pm โดย bom_002
การอ่านค่าความต้านทาน 4 แถบสี และ 5 แถบสี
โดย bom_002 พ 08 มี.ค. 2017 6:58 pm บอร์ด IOT - Internet of things
0
62
พ 08 มี.ค. 2017 6:58 pm โดย bom_002
ขอวิธีทำ ปุ่มแบ่งหน้าหน่อยค่ะ คือต้องให้คลิก >> แล้วแสดงตัวแบ่งถัดไปด้วย
โดย moomai พ 08 มี.ค. 2017 6:09 pm บอร์ด Programming - PHP
1
52
พ 08 มี.ค. 2017 6:09 pm โดย moomai
การสร้างงานนำเสนอด้วยโปรแกรม Prezi
โดย bom_002 พ 08 มี.ค. 2017 4:42 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
64
พ 08 มี.ค. 2017 4:42 pm โดย bom_002
ต้องการให้บรรทัดตารางแสดงข้อมูลคนละสีกันโดยใช้ bootstrap ต้องทำยังไงค่ะ
โดย moomai พ 08 มี.ค. 2017 3:53 pm บอร์ด Programming - PHP
0
48
พ 08 มี.ค. 2017 3:53 pm โดย moomai
Normalization (นอร์มัลไลเซชัน) ลดปัญหาการซ้ำซ้อนของข้อมูลในฐานข้อมูล
โดย bom_002 พ 08 มี.ค. 2017 2:55 pm บอร์ด Programming - C/C++ & java & Python
0
62
พ 08 มี.ค. 2017 2:55 pm โดย bom_002
ถ้าเราต้องการเขียนโค้ดแสดงตำแหน่งจากหมายเลข IP ต้องทำยังไงคะ
โดย moomai อ 07 มี.ค. 2017 7:06 pm บอร์ด Programming - PHP
3
77
อ 07 มี.ค. 2017 7:06 pm โดย tsukasaz
การใช้โปรแกรม Pycharm บนระบบปฏิบัติการ Ubuntu
โดย bom_002 อ 07 มี.ค. 2017 5:40 pm บอร์ด Python Knowledge
0
80
อ 07 มี.ค. 2017 5:40 pm โดย bom_002
ทำความรู้จัก bootstrap 4
โดย moomai อ 07 มี.ค. 2017 4:21 pm บอร์ด Mindphp Videoman
0
72
อ 07 มี.ค. 2017 4:21 pm โดย moomai
มีอะไรใหม่บ้าง ใน Joomla 3.5
โดย moomai อ 07 มี.ค. 2017 4:11 pm บอร์ด Mindphp Videoman
0
42
อ 07 มี.ค. 2017 4:11 pm โดย moomai
การเดินทางไป-กลับ อุบลราชธานี กรุงเทพฯ ด้วยรถไฟ
โดย bom_002 อ 07 มี.ค. 2017 12:07 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
35
อ 07 มี.ค. 2017 12:07 pm โดย bom_002
บันทึกข้อความร่างไว้แล้วหาไม่เจอ
โดย bom_002 อ 07 มี.ค. 2017 11:38 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
4
80
อ 07 มี.ค. 2017 11:38 am โดย bom_002