3.0 KiB
3.0 KiB
id, title, challengeType, forumTopicId, dashedName
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
589fc831f9fc0f352b528e75 | 通過 Emitting 通信 | 2 | 301550 | communicate-by-emitting |
--description--
Emit 是你會用到的最常見的通信方式。 如果我們從服務器發送信息給 “io”,就相當於把事件的名稱和數據發送給了所有處於連接狀態的 socket。 我們可以利用這個特性實現這樣的功能:只要有新用戶連接到服務器,我們就可以把目前連接的總用戶數發給所有已連接的用戶,這樣所有用戶隨時都可以看到實時的在線人數。
首先,我們需要在監聽連接的地方之前添加一個用於追蹤用戶數的變量:
let currentUsers = 0;
然後,只要有人連接到服務器,就需要在發出用戶數量之前先給這個變量加 1。 因此,需要在連接監聽器中增加一個遞增器。
++currentUsers;
最後,在監聽連接的地方發出(emit)該事件即可。 這個事件應命名爲 “user count”,且數據應該爲 currentUsers
:
io.emit('user count', currentUsers);
現在,你實現了在客戶端監聽此事件。 類似在服務器上監聽連接,你將使用 on
關鍵字。
socket.on('user count', function(data) {
console.log(data);
});
現在你可以嘗試啓動你的 app 並登錄,你會看到在客戶端的控制檯打印出了 “1”,這就表示目前連接到服務器的用戶數爲 1。 你可以試着通過打開多個 app 來驗證數量是否會增加。
完成上述要求後,請提交你的頁面鏈接。 如果你遇到了問題,可以參考這裏的答案。
--hints--
應定義 currentUsers。
(getUserInput) =>
$.get(getUserInput('url') + '/_api/server.js').then(
(data) => {
assert.match(
data,
/currentUsers/gi,
'You should have variable currentUsers defined'
);
},
(xhr) => {
throw new Error(xhr.statusText);
}
);
服務器應在有新的連接時發送當前用戶數量。
(getUserInput) =>
$.get(getUserInput('url') + '/_api/server.js').then(
(data) => {
assert.match(
data,
/io.emit.*('|")user count('|").*currentUsers/gi,
'You should emit "user count" with data currentUsers'
);
},
(xhr) => {
throw new Error(xhr.statusText);
}
);
客戶端應監聽 “user count” 事件。
(getUserInput) =>
$.get(getUserInput('url') + '/public/client.js').then(
(data) => {
assert.match(
data,
/socket.on.*('|")user count('|")/gi,
'Your client should be connection to server with the connection defined as socket'
);
},
(xhr) => {
throw new Error(xhr.statusText);
}
);
--solutions--
/**
Backend challenges don't need solutions,
because they would need to be tested against a full working project.
Please check our contributing guidelines to learn more.
*/