ให้เรตสมาชิก: 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
สอบถามจะย้ายตำแหน่งรายการ Drop Down ไปไว้ทางด้านซ้าย
โดย AePongsak ศ 15 ก.ย. 2017 4:47 pm บอร์ด HTML CSS
2
88
ศ 15 ก.ย. 2017 4:47 pm โดย AePongsak
วิธีติดตั้ง geckodriver เพื่อใช้งานกลับ Webdriver.Firefox บน Ubuntu
โดย nuattawoot ศ 15 ก.ย. 2017 4:31 pm บอร์ด Programming - C/C++ & java & Python
0
59
ศ 15 ก.ย. 2017 4:31 pm โดย nuattawoot
คนทั่วไปที่เข้าใจ (ผิด) ที่เกี่ยวกับ IT Support
โดย Before Dong ศ 15 ก.ย. 2017 9:27 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
124
ศ 15 ก.ย. 2017 9:27 am โดย Before Dong
จะเข้าเฟสเก่าแต่ทำไม่ได้
โดย วนิดา ซังธาดา พฤ 14 ก.ย. 2017 1:38 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
0
57
พฤ 14 ก.ย. 2017 1:38 pm โดย วนิดา ซังธาดา
เปิดใช้ plugin msocial แล้วบทความหาย
โดย meeieis พฤ 14 ก.ย. 2017 1:08 pm บอร์ด Joomla Development
4
85
พฤ 14 ก.ย. 2017 1:08 pm โดย meeieis
โฉมหน้า "แชมป์" การเล่นซ่อนแอบตลอดกาล
โดย Before Dong พฤ 14 ก.ย. 2017 10:35 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
81
พฤ 14 ก.ย. 2017 10:35 am โดย Before Dong
ตอนเขียนมันก็รันได้ ตอน Test มันก็ผ่าน แต่ใช้งานจริง ทำไมเป็นแบบนั้น
โดย AePongsak พ 13 ก.ย. 2017 7:52 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
194
พ 13 ก.ย. 2017 7:52 pm โดย AePongsak
B - ติดตั้งเวอร์ชั่น 1.0.3 ไม่ได้
โดย tsukasaz พ 13 ก.ย. 2017 6:30 pm บอร์ด MyFrontPageDesign
0
1
พ 13 ก.ย. 2017 6:30 pm โดย tsukasaz
แนวทางการเป็น Programmer (โปรแกรมเมอร์)
โดย nuattawoot พ 13 ก.ย. 2017 5:39 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
90
พ 13 ก.ย. 2017 5:39 pm โดย nuattawoot
TIP ดูหน้าจอ ตอน boot เข้า OS ของ CentOS แบบ Command
โดย mindphp พ 13 ก.ย. 2017 2:55 pm บอร์ด Linux - Web Server
0
68
พ 13 ก.ย. 2017 2:55 pm โดย mindphp
การสร้างตารางในฐานข้อมูล PostgreSQL (โพสต์เกรสคิวเอล) แบบใช้โค้ด SQL
โดย natnicha001 พ 13 ก.ย. 2017 2:22 pm บอร์ด SQL - Database
0
65
พ 13 ก.ย. 2017 2:22 pm โดย natnicha001
การเขียน selenium webdriver ด้วยภาษา python
โดย natnicha001 พ 13 ก.ย. 2017 10:29 am บอร์ด Programming - C/C++ & java & Python
28
360
พ 13 ก.ย. 2017 12:56 pm โดย mindphp
ทดสอบว่าคุณเป็น "โปรแกรมเมอร์" หรือไม่ ด้วยการนับแอปเปิ้ล
โดย Before Dong พ 13 ก.ย. 2017 10:19 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
3
147
พ 13 ก.ย. 2017 10:19 am โดย Before Dong
อยากถามการทำเว็บฝากขายจะดำเนินการอย่างไรใน Joomla ได้บ้างครับ
โดย giantseed พ 13 ก.ย. 2017 9:39 am บอร์ด Joomla Development
2
89
พ 13 ก.ย. 2017 9:39 am โดย giantseed
การเขียนโปรแกรม แบบ MVC Pattern ของโปรแกรมเมอร์
โดย Before Dong อ 12 ก.ย. 2017 10:32 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
132
อ 12 ก.ย. 2017 10:32 am โดย Before Dong
ติดตั้ง โปรแกรมช่วย ตรวจสอบ Malware ในระบบด้วย Linux Malware Detect LMD บน CentOS
โดย mindphp จ 11 ก.ย. 2017 4:52 pm บอร์ด Linux - Web Server
1
65
จ 11 ก.ย. 2017 4:52 pm โดย mindphp
สอบถามโปรแกรมจำรองมือถือ Genymotion กด Start ไม่ได้
โดย AePongsak จ 11 ก.ย. 2017 4:32 pm บอร์ด Mobile Programming - Android, iOS, Window Phone
0
73
จ 11 ก.ย. 2017 4:32 pm โดย AePongsak
วิธีตั้งค่าให้ Gmail แจ้งเตือนทางเดสก์ท็อป
โดย AePongsak จ 11 ก.ย. 2017 4:16 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
0
97
จ 11 ก.ย. 2017 4:16 pm โดย AePongsak
Q - อยากทราบวิธี รัน selenium บน Firefox เวอร์ชั่น 55.0.3
โดย M029 จ 11 ก.ย. 2017 2:36 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
0
70
จ 11 ก.ย. 2017 2:36 pm โดย M029
Q - อยากทราบวิธีไม่ให้ Mozilla Firefox อัพเดท Auto ครับ
โดย M029 จ 11 ก.ย. 2017 2:34 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
2
82
จ 11 ก.ย. 2017 2:34 pm โดย M029