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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
Tip CSS : Word Breaking (การทำให้ text html element ไม่ล้น)
โดย pprn พ 11 ก.ค. 2018 4:46 pm บอร์ด CSS Knowledge
0
19
พ 11 ก.ค. 2018 4:46 pm โดย pprn
Tip CSS : CSS Word Wrap (การแสดงขึ้นบรรทัดใหม่ตามความยาวที่กำหนด)
โดย pprn พ 11 ก.ค. 2018 4:23 pm บอร์ด CSS Knowledge
0
15
พ 11 ก.ค. 2018 4:23 pm โดย pprn
Tip CSS : Text Overflow (การแสดงข้อความแบบตัดคำ)
โดย pprn พ 11 ก.ค. 2018 4:02 pm บอร์ด CSS Knowledge
0
23
พ 11 ก.ค. 2018 4:02 pm โดย pprn
Tip CSS : Box Shadow Effects (เอฟเฟ็คเงาของกล่องข้อความ)
โดย pprn พ 11 ก.ค. 2018 3:26 pm บอร์ด CSS Knowledge
0
19
พ 11 ก.ค. 2018 3:26 pm โดย pprn
การใช้งาน relay ร่วมกับ บอร์ด raspberri pi
โดย prakon พ 11 ก.ค. 2018 3:15 pm บอร์ด IOT - Internet of things
0
38
พ 11 ก.ค. 2018 3:15 pm โดย prakon
Tip CSS : Text Shadow Effects (เอฟเฟ็คเงาของตัวอักษร)
โดย pprn พ 11 ก.ค. 2018 2:46 pm บอร์ด CSS Knowledge
0
12
พ 11 ก.ค. 2018 2:46 pm โดย pprn
การใช้งาน gitlab ร่วมกับ netbean เบื้องต้น
โดย pprn พ 11 ก.ค. 2018 2:15 pm บอร์ด Joomla Developing Knowledge
0
26
พ 11 ก.ค. 2018 2:15 pm โดย pprn
งานประจำวันที่ 11 กรกฏาคม 2561
โดย pprn พ 11 ก.ค. 2018 10:43 am บอร์ด MT25 - นางสาวปรียากมล รินนาศักดิ์
1
28
พ 11 ก.ค. 2018 12:22 pm โดย pprn
งานประจำวันที่ 11 กรกฎาคม 2561
โดย prakon พ 11 ก.ค. 2018 10:20 am บอร์ด MT24 - นายปกรณ์ วิริยะธนวิโรจน์
0
22
พ 11 ก.ค. 2018 10:20 am โดย prakon
งานประจำวันที่ 11 กรกฎาคม 2018
โดย tatiya พ 11 ก.ค. 2018 9:50 am บอร์ด M065 - ตติยะ นาชัย
2
50
พ 11 ก.ค. 2018 6:09 pm โดย AePongsak
USB 3.1 with Gen 1 เเละ USB Type-C port คืออะไรค่ะ
โดย thatsawan พ 11 ก.ค. 2018 9:25 am บอร์ด ถาม - ตอบ คอมพิวเตอร์
1
30
พฤ 12 ก.ค. 2018 4:40 am โดย mindphp
B - การใช้งาน Key รายการผิด so, inv, ใบเสร็จ vat ไม่ตรงความความเป็นจริง
โดย mindphp อ 10 ก.ค. 2018 10:53 pm บอร์ด M.D.Soft Co.,Ltd. - Tester
0
3
อ 10 ก.ค. 2018 10:53 pm โดย mindphp
[ปัญหา] ใช้ภาษา python เชื่อมต่อกับฐานข้อมูล PostgreSQL แล้วไม่สามารถอัพข้อมูลขึ้นตารางได้บางส่วน
โดย prakon อ 10 ก.ค. 2018 7:00 pm บอร์ด Programming - C/C++ & java & Python
3
74
พ 11 ก.ค. 2018 11:50 am โดย nuattawoot
สอบถามการใช้งาน Joomla ครับ ปิด Title ของเมนูทำยังไง
โดย AePongsak อ 10 ก.ค. 2018 6:27 pm บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS CRM
1
20
อ 10 ก.ค. 2018 6:32 pm โดย AePongsak
สอบถามครับ วิธี connect database phpMyAdmin
โดย tatiya อ 10 ก.ค. 2018 6:26 pm บอร์ด SQL - Database
0
29
อ 10 ก.ค. 2018 6:26 pm โดย tatiya
ฺB - โลโก้บริษัทเป็นแบบเก่า
โดย taemmynatchapon อ 10 ก.ค. 2018 4:16 pm บอร์ด M.D.Soft Co.,Ltd. - Tester
0
3
อ 10 ก.ค. 2018 4:16 pm โดย taemmynatchapon
การใช้ Dynamic Progress Bar with Labels ใน CSS
โดย pprn อ 10 ก.ค. 2018 4:11 pm บอร์ด CSS Knowledge
0
13
อ 10 ก.ค. 2018 4:11 pm โดย pprn
การใช้งาน Dynamic Progress Bar ใน CSS
โดย pprn อ 10 ก.ค. 2018 3:51 pm บอร์ด CSS Knowledge
0
13
อ 10 ก.ค. 2018 3:51 pm โดย pprn
สอบถามวิธีใช้งาน Lamp ครับ
โดย tatiya อ 10 ก.ค. 2018 3:45 pm บอร์ด SQL - Database
2
29
อ 10 ก.ค. 2018 4:12 pm โดย tatiya
Tip CSS : Navigation Tabs in Grid (เนวิเกชั่น แท็บส์ ในกริด) อย่างง่าย
โดย pprn อ 10 ก.ค. 2018 3:18 pm บอร์ด CSS Knowledge
0
13
อ 10 ก.ค. 2018 3:18 pm โดย pprn