日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

大家經(jīng)常瀏覽一些網(wǎng)站時(shí)候會(huì)彈出在線聊天窗口,點(diǎn)擊后可以和客服人員聊天,非常方便,之前也做過一款簡(jiǎn)單的在線聊天工具,下面就說說在線聊天通訊的主要幾種技術(shù)手段。

1、Ajax

在html5之前,這個(gè)是很主流的web通訊方式,通過ajax不斷請(qǐng)求服務(wù)器獲取數(shù)據(jù),分為輪詢和長(zhǎng)輪詢,主要寫法上有點(diǎn)區(qū)別。

輪詢

輪詢是一種“拉”取信息的工作模式,設(shè)置一個(gè)定時(shí)器,定時(shí)詢問服務(wù)器是否有信息,每次建立連接傳輸數(shù)據(jù)之后,鏈接會(huì)關(guān)閉,演示代碼如下:

var polling = function(url, type, data){
 var xhr = new XMLHttpRequest(),
 type = type || "GET",
 data = data || null;
 xhr.onreadystatechange = function(){
 if(xhr.readyState == 4) {
 receive(xhr.responseText);
 xhr.onreadystatechange = null;
 }
 };
 xhr.open(type, url, true);
 xhr.send(type == "GET" ? null : data);
};
//定時(shí)器
var timer = setInterval(function(){
 polling();
}, 1000);

長(zhǎng)輪詢

長(zhǎng)輪詢其實(shí)也沒啥特殊的地方,就是在xhr對(duì)象關(guān)閉連接的時(shí)候馬上又發(fā)起請(qǐng)求,讓連接一直持續(xù)進(jìn)行,演示代碼如下:

var longPoll = function(type, url){
 var xhr = new XMLHttpRequest();
 xhr.onreadystatechange = function(){
 // 狀態(tài)為 4,數(shù)據(jù)傳輸完畢,重新遞歸連接
 if(xhr.readyState == 4) {
 receive(xhr.responseText);
 xhr.onreadystatechange = null;
 longPoll(type, url);
 }
 };
 xhr.open(type, url, true);
 xhr.send();
}

2、websocket

websocket是前端一個(gè)神器,ajax用了這么久了,相關(guān)技術(shù)也是很成熟,不過實(shí)現(xiàn)數(shù)據(jù)的拉取非常不劃算。

ajax是基于HTTP協(xié)議,HTTP協(xié)議是單向通信協(xié)議,只有客戶端發(fā)起HTTP請(qǐng)求,服務(wù)端才會(huì)返回?cái)?shù)據(jù)。

而WebSocket協(xié)議是雙向通信協(xié)議,在建立連接之后,客戶端和服務(wù)器都可以主動(dòng)向?qū)Ψ桨l(fā)送或接受數(shù)據(jù)。WebSocket協(xié)議建立的前提需要借助HTTP協(xié)議,建立連接之后,持久連接的雙向通信就與HTTP協(xié)議無關(guān)了。

下面直接上代碼,自從有了websocket,是不是感覺世界變得輕巧很多了。

var ws = new WebSocket("ws://www.example.com:8888");
ws.onopen = function(evt){};
ws.onmessage = function(evt){
 deal(evt.data);
};
ws.onclose = function(evt){};
//ws.close();

新建一個(gè)WebSocket實(shí)例,一切就OK了,ws:// 是websocket的連接協(xié)議,8888為端口號(hào)碼。onmessage中提供了data這個(gè)屬性,相當(dāng)方便

分享到:
標(biāo)簽:javascript
用戶無頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定