ให้เรตสมาชิก: 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
B - หน้าสมัครสมาชิก Error ไม่รู้จัก Column
โดย mindphp ส 04 มี.ค. 2017 8:32 pm บอร์ด Hachana - E-commerce
1
11
ส 04 มี.ค. 2017 8:32 pm โดย tsukasaz
การใช้งานเกี่ยวกับ vat 0%
โดย M029 ส 04 มี.ค. 2017 7:09 pm บอร์ด OpenERP Light Manual & เทคนิคการใช้งาน
0
6
ส 04 มี.ค. 2017 7:09 pm โดย M029
R - สูตร Excel การวิ่งของข้อมูล
โดย Amp_Audit ส 04 มี.ค. 2017 11:56 am บอร์ด OpenERP Light Tester
4
34
ส 04 มี.ค. 2017 11:56 am โดย Amp_Audit
สนใจลูกเล่นเว็บจัดเสปค ของ notebookspec
โดย บุคคลทั่วไป ศ 03 มี.ค. 2017 7:50 pm บอร์ด Programming - PHP
1
42
ศ 03 มี.ค. 2017 7:50 pm โดย บุคคลทั่วไป
Vmware
โดย Atit Nirasphai ศ 03 มี.ค. 2017 3:47 pm บอร์ด Programming - PHP
3
57
ศ 03 มี.ค. 2017 3:47 pm โดย Oh_nO
ขอวิธีทำ pahtway ของแต่ละหน้า ต้องเริ่มจากตรงไหนเขียนโค้ดคะ
โดย moomai ศ 03 มี.ค. 2017 2:28 pm บอร์ด Programming - PHP
1
48
ศ 03 มี.ค. 2017 2:28 pm โดย thatsawan
CRM (ซีอาร์เอ็ม) คืออะไร
โดย moomai ศ 03 มี.ค. 2017 10:12 am บอร์ด Microsoft Office Knowledge & line & Etc
0
39
ศ 03 มี.ค. 2017 10:12 am โดย moomai
ตั้งรหัสผ่านให้กับ MySQL xampp
โดย mindphp ศ 03 มี.ค. 2017 6:09 am บอร์ด Linux - Web Server
1
39
ศ 03 มี.ค. 2017 6:09 am โดย mindphp
วิธีแก้ปัญหา เข้า phpMyadin ไม่ได้หลังจากติดตั้ง xampp - New XAMPP security concept:
โดย mindphp ศ 03 มี.ค. 2017 5:37 am บอร์ด Linux - Web Server
1
61
ศ 03 มี.ค. 2017 5:37 am โดย mindphp
ติดตั้ง xampp แบบจานด่วน บน Ubuntu php 7.1
โดย mindphp ศ 03 มี.ค. 2017 5:30 am บอร์ด Linux - Web Server
1
114
ศ 03 มี.ค. 2017 5:30 am โดย mindphp
ถามวิธีการสร้าง workflow ค่ะ
โดย dawthana พฤ 02 มี.ค. 2017 6:29 pm บอร์ด OpenERP
0
4
พฤ 02 มี.ค. 2017 6:29 pm โดย dawthana
IP Address (ไอพีแอดเดรส) คืออะไร
โดย moomai พฤ 02 มี.ค. 2017 6:20 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
44
พฤ 02 มี.ค. 2017 6:20 pm โดย moomai
ภาษีหัก ณ ที่จ่าย คืออะไร
โดย moomai พฤ 02 มี.ค. 2017 6:17 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
34
พฤ 02 มี.ค. 2017 6:17 pm โดย moomai
ลืมรหัดผ่าน
โดย บุคคลทั่วไป พ 01 มี.ค. 2017 11:54 pm บอร์ด Programming - PHP
0
31
พ 01 มี.ค. 2017 11:54 pm โดย บุคคลทั่วไป
B-รายงานภาษีซื้อ
โดย M029 พ 01 มี.ค. 2017 8:14 pm บอร์ด OpenERP Light Tester
0
6
พ 01 มี.ค. 2017 8:14 pm โดย M029
สอนติดตั้ง ภาษาไทย ลงใน Joomla (จูมล่า)
โดย moomai พ 01 มี.ค. 2017 7:15 pm บอร์ด Mindphp Videoman
0
51
พ 01 มี.ค. 2017 7:15 pm โดย moomai
B-รายงานภาษีขายไม่มียอด
โดย M029 พ 01 มี.ค. 2017 7:01 pm บอร์ด OpenERP Light Tester
0
6
พ 01 มี.ค. 2017 7:01 pm โดย M029
แนะนำวิธีการเพิ่มผู้ใช้ที่เป็น Admin (แอดมิน) เข้าใช้งานใน Joomla (จูมล่า)
โดย moomai พ 01 มี.ค. 2017 6:31 pm บอร์ด Mindphp Videoman
0
36
พ 01 มี.ค. 2017 6:31 pm โดย moomai
บริการพร้อมเพย์ธุรกิจ(Business promptpay) ดียังไงครับ ข้อดี-ข้อเสีย ??
โดย M029 พ 01 มี.ค. 2017 6:13 pm บอร์ด ถาม - ตอบ ธุรกิจ กฏหมาย ภาษี บัญชี
0
38
พ 01 มี.ค. 2017 6:13 pm โดย M029
B - [Odoo] ใส่รายละเอียดรูปภาพเป็นภาษาอื่นๆ ไม่ได้
โดย tsukasaz พ 01 มี.ค. 2017 5:15 pm บอร์ด Hachana - E-commerce
1
8
พ 01 มี.ค. 2017 5:15 pm โดย tsukasaz