ให้เรตสมาชิก: 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
มีวิธีเปลี่ยนจาก ip เป็น domain ไหมครับ
โดย mcmakdonal จ 24 เม.ย. 2017 10:44 am บอร์ด Joomla Development
1
67
จ 24 เม.ย. 2017 10:44 am โดย tsukasaz
แจกฟรี สคริปต์ระบบบันทึกรายรับ-รายจ่าย PHP
โดย กรกฎ วิริยะ จ 24 เม.ย. 2017 8:56 am บอร์ด Free PHP Code Download script
0
75
จ 24 เม.ย. 2017 8:56 am โดย กรกฎ วิริยะ
AI (เอไอ) คืออะไร
โดย bom_002 ส 22 เม.ย. 2017 12:44 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
53
ส 22 เม.ย. 2017 12:44 pm โดย bom_002
LAMP Server (แลบ เซิร์ฟเวอร์) คืออะไร
โดย bom_002 ศ 21 เม.ย. 2017 8:01 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
71
ศ 21 เม.ย. 2017 8:01 pm โดย bom_002
firefox เวอร์ชั่นใหม่ เวอร์บั่น 53.0
โดย mindphp ศ 21 เม.ย. 2017 7:47 pm บอร์ด PHP News
0
66
ศ 21 เม.ย. 2017 7:47 pm โดย mindphp
การเก็บรวบรวมข้อมูล
โดย bom_002 ศ 21 เม.ย. 2017 4:46 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
58
ศ 21 เม.ย. 2017 4:46 pm โดย bom_002
สอนย้ายข้อมูล Joomla จากเครื่องตัวเองขึ้นเว็บ Server
โดย moomai ศ 21 เม.ย. 2017 12:52 pm บอร์ด Mindphp Videoman
3
103
ศ 21 เม.ย. 2017 12:52 pm โดย Jubtot Kkn
มีวิธีการ Login เข้า joomla โดยแค่ส่ง parameter ไปที่หน้าสักหน้า แล้ว Login เลยเป็นไปได้ไหมครับ
โดย mcmakdonal ศ 21 เม.ย. 2017 9:13 am บอร์ด Joomla Development
3
126
ศ 21 เม.ย. 2017 9:13 am โดย mcmakdonal
อยากทราบวิธีการดึงข้อมูล ละติจูด ลองติจูด มาแสดงบน google
โดย pnut พฤ 20 เม.ย. 2017 4:47 pm บอร์ด Mobile Programming - Android, iOS, Window Phone
0
62
พฤ 20 เม.ย. 2017 4:47 pm โดย pnut
SQL กับ MySQL เหมือนกันมั้ย ถ้าไม่เหหมือนต่างกันยังไง
โดย moomai ศ 03 ก.พ. 2017 5:16 pm บอร์ด SQL Knowledge
1
125
พฤ 20 เม.ย. 2017 2:11 pm โดย mindphp
มีวิธีเปลี่ยนจากใช้ db เป็น mysql เป็น sql server ไหมครับ
โดย lancelot พฤ 20 เม.ย. 2017 1:08 pm บอร์ด Joomla Development
3
75
พฤ 20 เม.ย. 2017 1:08 pm โดย mindphp
Yii 1.1.18 ออกแ้ว support PHP 7 แล้ว
โดย mindphp พฤ 20 เม.ย. 2017 8:21 am บอร์ด PHP News
0
66
พฤ 20 เม.ย. 2017 8:21 am โดย mindphp
เป็นที่เน็ต,คอมหรือวินโดวส์ค้ะ
โดย บุคคลทั่วไป พ 19 เม.ย. 2017 11:23 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
0
32
พ 19 เม.ย. 2017 11:23 pm โดย บุคคลทั่วไป
ระบบปฏิบัติการ Solaris (โซลาริส)
โดย bom_002 พ 19 เม.ย. 2017 5:54 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
52
พ 19 เม.ย. 2017 5:54 pm โดย bom_002
ต้องการหารเวลากับจำนวนเต็มแล้วผลออกมาเป็นเวลาต้องทำยังไงคะ
โดย moomai พ 19 เม.ย. 2017 3:20 pm บอร์ด Programming - PHP
3
165
พ 19 เม.ย. 2017 3:20 pm โดย Jubtot Kkn
วิธีทำ Alias กูเกิ้ล Gmail - How to create an Alias On Gmail
โดย AePongsak พ 19 เม.ย. 2017 2:53 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
0
48
พ 19 เม.ย. 2017 2:53 pm โดย AePongsak
CCleaner (ซีคลีนเนอร์) โปรแกรมที่จะช่วยให้คอมพิวเตอร์เร็วขึ้น
โดย bom_002 พ 19 เม.ย. 2017 12:04 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
62
พ 19 เม.ย. 2017 12:04 pm โดย bom_002
แนะนำโปรแกรมเสริมความปลอดภัยของ Linux - Web Server อย่าง fail2ban ใช้ได้ทั้ง Ubuntu และ CentOS
โดย mindphp พ 19 เม.ย. 2017 5:56 am บอร์ด Linux - Web Server
0
56
พ 19 เม.ย. 2017 5:56 am โดย mindphp
แก้ปัญหา postgresql start ไม่ได้ เจอข้อความ Insecure directory in $ENV{PATH} while running with -T switch at /usr/bin/pg
โดย mindphp พ 19 เม.ย. 2017 5:32 am บอร์ด Linux - Web Server
1
43
พ 19 เม.ย. 2017 5:32 am โดย mindphp
บันทึกแก้ปัญหา Server โดน malware บน CentOS และ Ubuntu
โดย mindphp พ 19 เม.ย. 2017 5:11 am บอร์ด Linux - Web Server
1
62
พ 19 เม.ย. 2017 5:11 am โดย mindphp