導航:首頁 > 編程語言 > nodejssocketio

nodejssocketio

發布時間:2024-11-02 10:49:42

❶ Vue.js如何使用Socket.IO的示例代碼



在很多需求業務中,都需要瀏覽器和伺服器實時通信來實現功能,比如:掃碼登錄(掃碼後,手機確認登錄,PC網頁完成登錄並跳轉)、訂單語言提醒等,這些都是建立在兩端實時通信的基礎上的。對前端而言,來實現瀏覽器和伺服器實時通信,最好的選擇就是Socket.IO庫,能夠快速的實現兩端實時通信功能。



1、什麼是 Socket.IO?

Socket.IO 是一個WebSocket庫,可以在瀏覽器和伺服器之間實現實時,雙向和基於事件的通信。它包括:Node.js伺服器庫、瀏覽器的javascript客戶端庫。它會自動根據瀏覽器從WebSocket、AJAX長輪詢、Iframe流等等各種方式中選擇最佳的方式來實現網路實時應用,非常方便和人性化,而且支持的瀏覽器最低達IE5.5

2、Socket.IO 主要特點



(1)、支持瀏覽器/Nodejs環境 (2)、支持雙向通信 (3)、API簡單易用 (4)、支持二進制傳輸 (5)、減少傳輸數據量

3、Vue.js 中 Socket.IO的使用



(1)客戶端

npm install vue-socket.io --save
main.js添加下列代碼

import VueSocketIO from 'vue-socket.io'

Vue.use(new VueSocketIO({
debug: true,
// 伺服器端地址
connection: 'http://localhost:3000',
vuex: {
}
}))
發送消息和監聽消息

//發送信息給服務端
this.$socket.emit('login',{
username: 'username',
password: 'password'
});
//接收服務端的信息
this.sockets.subscribe('relogin', (data) => {
console.log(data)
})
(2)服務端



服務端,我們基於express搭建node伺服器。

npm install --save express
npm install --save socket.io
index.js文件

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
app.get('/', function(req, res){
res.send('<h1>你好web秀</h1>');
});

io.on('connection',function(socket) {
//接收數據
socket.on('login', function (obj) {
console.log(obj.username);
// 發送數據
socket.emit('relogin', {
msg: `你好${obj.username}`,
code: 200
});
});
});

http.listen(3000, function(){
console.log('listening on *:3000');
});
然後啟動服務端服務

node index.js
客戶端即可查看效果。

4、Socket.IO有哪些事件



io.on('connect', onConnect);
function onConnect(socket){
// 發送給當前客戶端
socket.emit(
'hello',
'can you hear me?',
1,
2,
'abc'
);
// 發送給所有客戶端,除了發送者
socket.broadcast.emit(
'broadcast',
'hello friends!'
);
// 發送給同在 'game' 房間的所有客戶端,除了發送者
socket.to('game').emit(
'nice game',
"let's play a game"
);
// 發送給同在 'game1' 或 'game2' 房間的所有客戶端,除了發送者
socket.to('game1').to('game2').emit(
'nice game',
"let's play a game (too)"
);
// 發送給同在 'game' 房間的所有客戶端,包括發送者
io.in('game').emit(
'big-announcement',
'the game will start soon'
);
// 發送給同在 'myNamespace' 命名空間下的所有客戶端,包括發送者
io.of('myNamespace').emit(
'bigger-announcement',
'the tournament will start soon'
);
// 發送給指定 socketid 的客戶端(私密消息)
socket.to(<socketid>).emit(
'hey',
'I just met you'
);
// 包含回執的消息
socket.emit(
'question',
'do you think so?',
function (answer) {}
);
// 不壓縮,直接發送
socket.compress(false).emit(
'uncompressed',
"that's rough"
);
// 如果客戶端還不能接收消息,那麼消息可能丟失
socket.volatile.emit(
'maybe',
'do you really need it?'
);
// 發送給當前 node 實例下的所有客戶端(在使用多個 node 實例的情況下)
io.local.emit(
'hi',
'my lovely babies'
);
};

❷ java怎樣抓取網頁代碼中動態顯示的數據

不用Java去抓取啊,讓頁面將數據發送到後台不就好了??
如果是從別人的網站上抓取的話,應該也是可以的,好像用socketio可以的。看看nodejs是否可以搞定。

❸ 如何用websocket+nodejs實現web即時通信服務端

用websocket+nodejs實現web即時通信服務端,Socketio和nodejs配的不錯,建立了socket就可以listen和broadcast。

閱讀全文

與nodejssocketio相關的資料

熱點內容
ps入門必備文件 瀏覽:348
以前的相親網站怎麼沒有了 瀏覽:15
蘋果6耳機聽歌有滋滋聲 瀏覽:768
怎麼徹底刪除linux文件 瀏覽:379
編程中字體的顏色是什麼意思 瀏覽:534
網站關鍵詞多少個字元 瀏覽:917
匯川am系列用什麼編程 瀏覽:41
筆記本win10我的電腦在哪裡打開攝像頭 瀏覽:827
醫院單位基本工資去哪個app查詢 瀏覽:18
css源碼應該用什麼文件 瀏覽:915
編程ts是什麼意思呢 瀏覽:509
c盤cad佔用空間的文件 瀏覽:89
不銹鋼大小頭模具如何編程 瀏覽:972
什麼格式的配置文件比較主流 瀏覽:984
增加目錄word 瀏覽:5
提取不相鄰兩列數據如何做圖表 瀏覽:45
r9s支持的網路制式 瀏覽:633
什麼是提交事務的編程 瀏覽:237
win10打字卡住 瀏覽:774
linux普通用戶關機 瀏覽:114

友情鏈接