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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
งานประจำวันที่ 7 กันยายน 2561
โดย muneela ศ 07 ก.ย. 2018 9:28 am บอร์ด M068 - มุนีลา หมัดบาซา
4
24
อ 09 ก.ย. 2018 9:32 pm โดย thatsawan
งานประจำวันที่ 7 กันยายน 2561
โดย tatiya ศ 07 ก.ย. 2018 9:23 am บอร์ด M065 - ตติยะ นาชัย
3
13
ศ 07 ก.ย. 2018 7:53 pm โดย tatiya
งานประจำวันที่ 7 กันยายน 2561
โดย prakon ศ 07 ก.ย. 2018 9:13 am บอร์ด MT24 - นายปกรณ์ วิริยะธนวิโรจน์
3
19
จ 10 ก.ย. 2018 10:22 am โดย prakon
งานประจำวันที่ 7 กันยายน 2561
โดย pprn ศ 07 ก.ย. 2018 9:11 am บอร์ด MT25 - นางสาวปรียากมล รินนาศักดิ์
1
15
ศ 07 ก.ย. 2018 5:56 pm โดย pprn
งานประจำวันที่ 7 กันยายน 2561
โดย tai14 ศ 07 ก.ย. 2018 9:09 am บอร์ด MT26 - นางสาวอัครยุภา ยงยุทธ
1
12
ศ 07 ก.ย. 2018 5:52 pm โดย tai14
VDO - แนะนำการใช้ tools_pmt
โดย pprn พฤ 06 ก.ย. 2018 5:32 pm บอร์ด MT25 - นางสาวปรียากมล รินนาศักดิ์
0
31
พฤ 06 ก.ย. 2018 5:32 pm โดย pprn
ไอที Facebook แก้ปัญหาบน iPhone สามารถกด HD บนวิดีโอได้แล้ว
โดย thorng1 พฤ 06 ก.ย. 2018 3:47 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
37
พฤ 06 ก.ย. 2018 3:47 pm โดย thorng1
Q - สอบถามวิธีแปลง ascii บน python หน่อยครับ
โดย tatiya พฤ 06 ก.ย. 2018 10:46 am บอร์ด Programming - C/C++ & java & Python
7
104
พฤ 06 ก.ย. 2018 4:06 pm โดย tatiya
งานประจำวันที่ 6 กันยายน 2561
โดย prakon พฤ 06 ก.ย. 2018 10:22 am บอร์ด MT24 - นายปกรณ์ วิริยะธนวิโรจน์
1
15
พฤ 06 ก.ย. 2018 10:23 am โดย prakon
งานประจำวันที่ 6 กันยายน 2561
โดย muneela พฤ 06 ก.ย. 2018 10:07 am บอร์ด M068 - มุนีลา หมัดบาซา
1
19
พฤ 06 ก.ย. 2018 7:18 pm โดย muneela
งานประจำวันที่ 6 กันยายน 2561
โดย tatiya พฤ 06 ก.ย. 2018 10:07 am บอร์ด M065 - ตติยะ นาชัย
1
5
พฤ 06 ก.ย. 2018 9:38 pm โดย tatiya
งานประจำวันที่ 6 กันยายน 2561
โดย tai14 พฤ 06 ก.ย. 2018 10:05 am บอร์ด MT26 - นางสาวอัครยุภา ยงยุทธ
1
10
พฤ 06 ก.ย. 2018 7:03 pm โดย tai14
งานประจำวันที่ 6 กันยายน 2561
โดย pprn พฤ 06 ก.ย. 2018 10:04 am บอร์ด MT25 - นางสาวปรียากมล รินนาศักดิ์
1
16
พฤ 06 ก.ย. 2018 7:01 pm โดย pprn
เปิดการใช้งานบุคคลทั่วไปอย่างไร
โดย athikom พ 05 ก.ย. 2018 8:08 pm บอร์ด Joomla Development
1
61
พ 05 ก.ย. 2018 9:38 pm โดย mindphp
shop back คืออะไร
โดย muneela พ 05 ก.ย. 2018 6:52 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
51
พ 05 ก.ย. 2018 6:52 pm โดย muneela
ใช้ Navitcat มันโชว์ error แบบนี้ต้องเข้าไปแก้ไขอย่างไรบ้างค่ะ
โดย supattra_su พ 05 ก.ย. 2018 6:16 pm บอร์ด SQL - Database
0
43
พ 05 ก.ย. 2018 6:16 pm โดย supattra_su
AI ในปัจจุบันทำอะไรได้บ้าง
โดย muneela พ 05 ก.ย. 2018 4:59 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
42
พ 05 ก.ย. 2018 4:59 pm โดย muneela
ICon
โดย tai14 พ 05 ก.ย. 2018 3:25 pm บอร์ด MT26 - นางสาวอัครยุภา ยงยุทธ
2
20
ศ 07 ก.ย. 2018 2:54 pm โดย tai14
R - Symfony 2.8 สำหรับ Web Service
โดย tsukasaz พ 05 ก.ย. 2018 10:47 am บอร์ด สิริกิตติรัตน์ - Developer
0
8
พ 05 ก.ย. 2018 10:47 am โดย tsukasaz
งานประจำวันที่ 5 กันยายน 2561
โดย tatiya พ 05 ก.ย. 2018 10:05 am บอร์ด M065 - ตติยะ นาชัย
1
5
พ 05 ก.ย. 2018 9:53 pm โดย tatiya