ให้เรตสมาชิก: 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
ระบบดูแลร้านขายาและเภสัช
โดย บุคคลทั่วไป จ 02 ต.ค. 2017 1:20 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
48
จ 02 ต.ค. 2017 1:20 pm โดย บุคคลทั่วไป
Version ของ Window IOSและ android
โดย Before Dong จ 02 ต.ค. 2017 12:26 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
2
3049
จ 02 ต.ค. 2017 12:26 pm โดย mindphp
Software ระบบดูแลและช่วยเหลือการทำงาน คลินิคสัตวแพทย์ โรงพยาบาล และเพ็ทช็อป
โดย บุคคลทั่วไป จ 02 ต.ค. 2017 12:11 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
57
จ 02 ต.ค. 2017 12:11 pm โดย บุคคลทั่วไป
วิธีเปลี่ยน Port SSH Serve เพื่อ network security ที่ดีขึ้น
โดย mindphp อ 01 ต.ค. 2017 2:03 am บอร์ด Linux - Web Server
0
44
อ 01 ต.ค. 2017 2:03 am โดย mindphp
วิธีขายของ
โดย บุคคลทั่วไป ศ 29 ก.ย. 2017 11:11 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
44
ศ 29 ก.ย. 2017 11:11 pm โดย บุคคลทั่วไป
รับโปรแกรมเมอร์ (ขั้นเทพ)เขียนเว็ปไซร์ดึงข้อมูลแสดงผลประเภทกีฬา รายละเอียดด้านใน
โดย Nuntawat Songlaynu ศ 29 ก.ย. 2017 6:40 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
1
79
ศ 29 ก.ย. 2017 6:40 pm โดย konseo
Keyboard โปรแกรมเมอร์ไทย 4.0
โดย Before Dong ศ 29 ก.ย. 2017 9:40 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
2
1113
ศ 29 ก.ย. 2017 9:40 am โดย mindphp
มีใครลอง PHP 7.1.9 หรือยังครับ
โดย konseo พฤ 28 ก.ย. 2017 11:04 pm บอร์ด Programming - PHP
2
74
พฤ 28 ก.ย. 2017 11:04 pm โดย konseo
คำสั่งเช็คความเร็ว ของ CPU บน Linux Ubuntu cloud ที่ต่างๆ
โดย mindphp พฤ 28 ก.ย. 2017 7:36 pm บอร์ด Linux - Web Server
4
74
พฤ 28 ก.ย. 2017 7:36 pm โดย mindphp
[Extension phpBB 3.2.1] phpBB3 Advertisement Management (ระบบจัดการโฆษณา)
โดย AePongsak พฤ 28 ก.ย. 2017 6:02 pm บอร์ด phpBB 3.1 Extension Review
1
53
พฤ 28 ก.ย. 2017 6:02 pm โดย konseo
แชร์เรื่องอาการของปั้มน้ำ Hitachi ติดๆดับ ปัญหาคือเครื่องปั้มน้ำทำงานผิดปกติ
โดย บุคคลทั่วไป พฤ 28 ก.ย. 2017 2:56 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
1
53
พฤ 28 ก.ย. 2017 2:56 pm โดย บุคคลทั่วไป
เรื่องจริงของ "โปรแกรมเมอร์" ใครเป็นช่วยมายืนยันทีครับ
โดย Before Dong พฤ 28 ก.ย. 2017 10:40 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
3
164
พฤ 28 ก.ย. 2017 10:40 am โดย Before Dong
อยากรู้ว่าตัวอักษร หรือสัญลักษณ์อะไรบ้างที่ทำให้ xml error syntax ค่ะ
โดย thatsawan พฤ 28 ก.ย. 2017 10:02 am บอร์ด Programming - C/C++ & java & Python
0
34
พฤ 28 ก.ย. 2017 10:02 am โดย thatsawan
WIFI 2G กับ 5G ของ True ต่างกันยังงัยคะ
โดย thatsawan พ 27 ก.ย. 2017 11:11 am บอร์ด ถาม - ตอบ คอมพิวเตอร์
2
85
พ 27 ก.ย. 2017 11:11 am โดย Mote2010
ทดสอบว่าคุณเป็น "โปรแกรมเมอร์" หรือไม่ ด้วย Emoji
โดย Before Dong พ 27 ก.ย. 2017 10:37 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
3
160
พ 27 ก.ย. 2017 10:37 am โดย mindphp
ภาพนามสกุล heic image คืออะไรแล้วสร้างด้วยโปรแกรมอะไรค่ะ
โดย thatsawan อ 26 ก.ย. 2017 11:35 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
1
71
อ 26 ก.ย. 2017 11:35 pm โดย P'Eak
ดาวน์โหลด AtomyMaxsite CMS เวอร์ชั่นล่าสุด
โดย ayeweb6AFJV อ 26 ก.ย. 2017 11:13 pm บอร์ด Free PHP Code Download script
0
150
อ 26 ก.ย. 2017 11:13 pm โดย ayeweb6AFJV
สอบถามโปรแกรม CD ค่ะ
โดย บุคคลทั่วไป อ 26 ก.ย. 2017 1:59 pm บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS CRM
0
52
อ 26 ก.ย. 2017 1:59 pm โดย บุคคลทั่วไป
สอบถามเรื่อง getListFooter() ของ Joomla
โดย Minanda อ 26 ก.ย. 2017 1:18 pm บอร์ด Joomla Development
2
78
อ 26 ก.ย. 2017 1:18 pm โดย Minanda
Python Decorators
โดย nuattawoot อ 26 ก.ย. 2017 11:24 am บอร์ด Python Knowledge
2
91
อ 26 ก.ย. 2017 11:24 am โดย nuattawoot