精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

構(gòu)建一個(gè)即時(shí)消息應(yīng)用(八):Home 頁(yè)面

開發(fā) 后端
繼續(xù)前端部分,讓我們?cè)诒疚闹型瓿?home 頁(yè)面的開發(fā)。 我們將添加一個(gè)開始對(duì)話的表單和一個(gè)包含最新對(duì)話的列表。

[[346742]]

本文是該系列的第八篇。

繼續(xù)前端部分,讓我們?cè)诒疚闹型瓿?nbsp;home 頁(yè)面的開發(fā)。 我們將添加一個(gè)開始對(duì)話的表單和一個(gè)包含最新對(duì)話的列表。

對(duì)話表單

轉(zhuǎn)到 static/ages/home-page.js 文件,在 HTML 視圖中添加一些標(biāo)記。

 
  1. <form id="conversation-form"
  2.     <input type="search" placeholder="Start conversation with..." required> 
  3. </form> 

將該表單添加到我們顯示 “auth user” 和 “logout” 按鈕部分的下方。

  1. page.getElementById('conversation-form').onsubmit = onConversationSubmit 

現(xiàn)在我們可以監(jiān)聽 “submit” 事件來創(chuàng)建對(duì)話了。

  1. import http from '../http.js' 
  2. import { navigate } from '../router.js' 
  3.  
  4. async function onConversationSubmit(ev) { 
  5.     ev.preventDefault() 
  6.  
  7.     const form = ev.currentTarget 
  8.     const input = form.querySelector('input'
  9.  
  10.     input.disabled = true 
  11.  
  12.     try { 
  13.         const conversation = await createConversation(input.value) 
  14.         input.value = '' 
  15.         navigate('/conversations/' + conversation.id) 
  16.     } catch (err) { 
  17.         if (err.statusCode === 422) { 
  18.             input.setCustomValidity(err.body.errors.username) 
  19.         } else { 
  20.             alert(err.message) 
  21.         } 
  22.         setTimeout(() => { 
  23.             input.focus() 
  24.         }, 0) 
  25.     } finally { 
  26.         input.disabled = false 
  27.     } 
  28.  
  29. function createConversation(username) { 
  30.     return http.post('/api/conversations', { username }) 

在提交時(shí),我們使用用戶名對(duì) /api/conversations 進(jìn)行 POST 請(qǐng)求,并重定向到 conversation 頁(yè)面(用于下一篇文章)。

對(duì)話列表

還是在這個(gè)文件中,我們將創(chuàng)建 homePage() 函數(shù)用來先異步加載對(duì)話。

  1. export default async function homePage() { 
  2.     const conversations = await getConversations().catch(err => { 
  3.         console.error(err) 
  4.         return [] 
  5.     }) 
  6.     /*...*/ 
  7.  
  8. function getConversations() { 
  9.     return http.get('/api/conversations'

然后,在標(biāo)記中添加一個(gè)列表來渲染對(duì)話。

  1. <ol id="conversations"></ol> 

將其添加到當(dāng)前標(biāo)記的正下方。

  1. const conversationsOList = page.getElementById('conversations'
  2. for (const conversation of conversations) { 
  3.     conversationsOList.appendChild(renderConversation(conversation)) 

因此,我們可以將每個(gè)對(duì)話添加到這個(gè)列表中。

  1. import { avatar, escapeHTML } from '../shared.js' 
  2.  
  3. function renderConversation(conversation) { 
  4.     const messageContent = escapeHTML(conversation.lastMessage.content) 
  5.     const messageDate = new Date(conversation.lastMessage.createdAt).toLocaleString() 
  6.  
  7.     const li = document.createElement('li'
  8.     li.dataset['id'] = conversation.id 
  9.     if (conversation.hasUnreadMessages) { 
  10.         li.classList.add('has-unread-messages'
  11.     } 
  12.     li.innerHTML = ` 
  13.         <a href="/conversations/${conversation.id}"
  14.             <div> 
  15.                 ${avatar(conversation.otherParticipant)} 
  16.                 <span>${conversation.otherParticipant.username}</span> 
  17.             </div> 
  18.             <div> 
  19.                 <p>${messageContent}</p> 
  20.                 <time>${messageDate}</time
  21.             </div> 
  22.         </a> 
  23.     ` 
  24.     return li 

每個(gè)對(duì)話條目都包含一個(gè)指向?qū)υ掜?yè)面的鏈接,并顯示其他參與者信息和最后一條消息的預(yù)覽。另外,您可以使用 .hasUnreadMessages 向該條目添加一個(gè)類,并使用 CSS 進(jìn)行一些樣式設(shè)置。也許是粗體字體或強(qiáng)調(diào)顏色。

請(qǐng)注意,我們需要轉(zhuǎn)義信息的內(nèi)容。該函數(shù)來自于 static/shared.js 文件:

  1. export function escapeHTML(str) { 
  2.     return str 
  3.         .replace(/&/g, '&amp;'
  4.         .replace(/</g, '&lt;'
  5.         .replace(/>/g, '&gt;'
  6.         .replace(/"/g, '&quot;'
  7.         .replace(/'/g, '&#039;') 

這會(huì)阻止將用戶編寫的消息顯示為 HTML。如果用戶碰巧編寫了類似以下內(nèi)容的代碼:

<script>alert('lololo')</script>

這將非常煩人,因?yàn)樵撃_本將被執(zhí)行😅。所以,永遠(yuǎn)記住要轉(zhuǎn)義來自不可信來源的內(nèi)容。

消息訂閱

最后但并非最不重要的一點(diǎn),我想在這里訂閱消息流。

  1. const unsubscribe = subscribeToMessages(onMessageArrive) 
  2. page.addEventListener('disconnect', unsubscribe) 

在 homePage() 函數(shù)中添加這一行。

  1. function subscribeToMessages(cb) { 
  2.     return http.subscribe('/api/messages', cb) 

函數(shù) subscribe() 返回一個(gè)函數(shù),該函數(shù)一旦調(diào)用就會(huì)關(guān)閉底層連接。這就是為什么我把它傳遞給 “斷開連接”disconnect事件的原因;因此,當(dāng)用戶離開頁(yè)面時(shí),事件流將被關(guān)閉。

  1. async function onMessageArrive(message) { 
  2.     const conversationLI = document.querySelector(`li[data-id="${message.conversationID}"]`) 
  3.     if (conversationLI !== null) { 
  4.         conversationLI.classList.add('has-unread-messages'
  5.         conversationLI.querySelector('a > div > p').textContent = message.content 
  6.         conversationLI.querySelector('a > div > time').textContent = new Date(message.createdAt).toLocaleString() 
  7.         return 
  8.     } 
  9.  
  10.     let conversation 
  11.     try { 
  12.         conversation = await getConversation(message.conversationID) 
  13.         conversation.lastMessage = message 
  14.     } catch (err) { 
  15.         console.error(err) 
  16.         return 
  17.     } 
  18.  
  19.     const conversationsOList = document.getElementById('conversations'
  20.     if (conversationsOList === null) { 
  21.         return 
  22.     } 
  23.  
  24.     conversationsOList.insertAdjacentElement('afterbegin', renderConversation(conversation)) 
  25.  
  26. function getConversation(id) { 
  27.     return http.get('/api/conversations/' + id) 

每次有新消息到達(dá)時(shí),我們都會(huì)在 DOM 中查詢會(huì)話條目。如果找到,我們會(huì)將 has-unread-messages 類添加到該條目中,并更新視圖。如果未找到,則表示該消息來自剛剛創(chuàng)建的新對(duì)話。我們?nèi)プ鲆粋€(gè)對(duì) /api/conversations/{conversationID} 的 GET 請(qǐng)求,以獲取在其中創(chuàng)建消息的對(duì)話,并將其放在對(duì)話列表的前面。


以上這些涵蓋了主頁(yè)的所有內(nèi)容 😊。 在下一篇文章中,我們將對(duì) conversation 頁(yè)面進(jìn)行編碼。

 

 

責(zé)任編輯:龐桂玉 來源: Linux中國(guó)
相關(guān)推薦

2020-10-12 09:20:13

即時(shí)消息Access頁(yè)面編程語言

2020-10-19 16:20:38

即時(shí)消息Conversatio編程語言

2020-10-09 12:45:19

創(chuàng)建消息即時(shí)消息編程語言

2019-09-29 15:25:13

CockroachDBGoJavaScript

2020-10-09 15:00:56

實(shí)時(shí)消息編程語言

2019-10-28 20:12:40

OAuthGuard中間件編程語言

2020-03-31 12:21:20

JSON即時(shí)消息編程語言

2020-10-10 20:51:10

即時(shí)消息編程語言

2021-03-25 08:29:33

SpringBootWebSocket即時(shí)消息

2023-08-14 08:01:12

websocket8g用戶

2025-06-30 01:45:00

Netty輪詢HTTP 協(xié)議

2015-03-18 15:37:19

社交APP場(chǎng)景

2014-10-15 11:01:02

Web應(yīng)用測(cè)試應(yīng)用

2018-08-22 17:32:45

2022-02-10 07:03:32

流量應(yīng)用架構(gòu)數(shù)據(jù)交換

2023-09-21 08:00:00

ChatGPT編程工具

2021-07-14 17:39:46

ReactRails API前端組件

2025-05-30 03:00:00

AI開源工具

2021-12-03 00:02:01

通訊工具即時(shí)

2023-09-15 10:10:05

R 語言
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

亚洲一区不卡在线| 欧美激情aaaa| 亚洲一级免费在线观看| 69视频在线观看| 精品影院一区二区久久久| 日韩精品免费看| 国产精品秘入口18禁麻豆免会员| 亚洲av电影一区| 一区二区三区视频免费看| 麻豆网站在线| 国产高清视频一区| 91精品国产91久久久久久| 李宗瑞91在线正在播放| 日韩电影精品| 亚洲国产毛片aaaaa无费看| 美国av一区二区三区| 亚洲综合精品国产一区二区三区| 欧美三级第一页| 亚洲性xxxx| 国产在线观看免费播放| 182在线播放| 欧美韩日一区二区三区| 国产精品久久久久久久久久直播 | 久久久伊人欧美| 91精彩刺激对白露脸偷拍| 久久久免费人体| 亚洲成人精品一区| 一级黄色免费在线观看| 日韩偷拍自拍| 国产精品 欧美精品| 青青青国产精品一区二区| 乱h高h女3p含苞待放| 深爱激情综合网| 欧美α欧美αv大片| 亚洲精品一二三四五区| 91超碰在线播放| 亚洲欧美日韩国产另类专区| 亚洲欧美99| 福利在线视频导航| 97se亚洲国产综合自在线观| 91中文在线观看| 国产午夜无码视频在线观看| 这里只有精品在线| 夜夜嗨av一区二区三区四区| 国产大片一区二区三区| 二吊插入一穴一区二区| heyzo久久| 国精产品一区一区三区mba桃花 | 肉肉视频在线观看| 国产精品欧美综合在线| 日产中文字幕在线精品一区| 日本毛片在线观看| 国产精品一区专区| 91在线视频成人| 在线观看黄色网| 久久亚洲欧洲| 国产精品欧美亚洲777777| 天堂网中文字幕| 午夜亚洲影视| 98视频在线噜噜噜国产| 日本不卡一二区| 欧美一级精品| 亚洲天堂成人在线视频| 欧美丰满少妇人妻精品| 天堂网av成人| 亚洲精品国产精品国自产观看浪潮| 免费看三级黄色片| 欧美成人一级| 精品成人在线观看| 亚洲黄色小说在线观看| 国产人妖ts一区二区| av色综合久久天堂av综合| 欧美性一区二区| 各处沟厕大尺度偷拍女厕嘘嘘| 国产伦理精品| 精品久久久久人成| 成人观看免费完整观看| 亚洲www.| 欧美精品日韩一本| 日本精品一二三区| 九九久久婷婷| 在线观看欧美成人| 亚洲人做受高潮| 亚洲综合色站| 欧美高清在线视频观看不卡| 国产精品自拍视频一区| 美女久久一区| 国产日韩欧美91| 国产黄色免费大片| www.成人网.com| 欧美日本亚洲| 秋霞午夜在线观看| 亚洲最大成人综合| 欧美一区二区视频在线观看2020 | 11024精品一区二区三区日韩| 人人狠狠综合久久亚洲| 成人有码在线视频| 亚洲不卡免费视频| 久久久www成人免费无遮挡大片| 亚洲国产精品日韩| 最爽无遮挡行房视频在线| 亚洲成av人片| av免费一区二区| 综合激情五月婷婷| 亚洲第一区中文99精品| 国产全是老熟女太爽了| 91欧美在线| 国产综合在线看| 波多野结衣午夜| 国产综合成人久久大片91| 精品免费国产| 欧美日韩视频在线播放| 五月综合激情网| 日韩大片一区二区| 国产成人在线中文字幕| 亚洲乱码av中文一区二区| 秋霞网一区二区三区| 国内成人在线| 国产精品一区二区三区久久| 亚洲免费成人网| 久久天天做天天爱综合色| 最新欧美日韩亚洲| 欧美电影免费观看| 精品日韩欧美在线| 日本成人免费在线观看| 中文亚洲免费| 不卡视频一区二区三区| 日本黄大片在线观看| 久久经典视频| 一区二区三区在线高清| 亚洲xxxx2d动漫1| 国产美女撒尿一区二区| 日日狠狠久久偷偷四色综合免费 | 在线观看一区日韩| 久久人人妻人人人人妻性色av| 亚洲人成免费网站| 国产日韩视频在线观看| 国产视频二区在线观看| 精品福利在线视频| 中文字幕在线永久| 激情综合激情| 国产午夜精品一区| 国产美女精品写真福利视频| 欧美变态口味重另类| 久久精品波多野结衣| 国产一区二区久久| 三级网在线观看| 日本精品视频| 欧美理论片在线观看| va视频在线观看| 亚洲精选一二三| 波多野结衣免费观看| 亚洲欧美色图| 国产高清精品一区| 激情网站在线| 亚洲第一视频网站| 国产又黄又猛又粗又爽| 久久久久成人黄色影片| 精品久久久久久久免费人妻| 国产欧美日韩精品高清二区综合区| 日韩av片电影专区| 91精品国产91久久久久游泳池 | 精品久久久久久| 精品人妻一区二区三区香蕉| 亚洲欧美日韩国产一区二区| 日日噜噜噜噜夜夜爽亚洲精品| 国产黄色小视频网站| 亚洲午夜免费| 欧美亚洲国产日韩2020| 国产二区视频在线观看| 制服丝袜成人动漫| 久久这里只有精品国产| 91丨九色丨尤物| 亚洲色图久久久| 欧美一区激情| 久久精品日产第一区二区三区精品版| 九九热线视频只有这里最精品| 色妞久久福利网| 亚洲美女福利视频| 在线精品视频一区二区| 国产一区二区播放| 99久久精品免费精品国产| 日本www高清视频| 91精品国产福利在线观看麻豆| 99久久无色码| www.四虎成人| 日韩av一二三区| av动漫一区二区| 国产精品免费成人| 欧美激情理论| 国产一区二区三区黄| 手机看片久久| av日韩在线播放| 26uuu另类亚洲欧美日本老年| 成年人在线免费观看| 欧美一区午夜视频在线观看| 91九色丨porny丨肉丝| 欧美韩国日本不卡| 岛国精品一区二区三区| 免费精品99久久国产综合精品| 久久久久久久9| 欧美日韩在线观看视频小说| 99r国产精品视频| 成人网ww555视频免费看| 久操成人在线视频| jyzzz在线观看视频| 欧美精品一区二区三区一线天视频 | 欧美成人免费播放| 免费动漫网站在线观看| 欧美一卡2卡三卡4卡5免费| 岛国av中文字幕| 亚洲综合激情网| 在线视频这里只有精品| 99国产精品视频免费观看| 男人午夜视频在线观看| 免费日韩av片| 草b视频在线观看| 一区二区三区午夜探花| 日本免费高清不卡| 久久精品福利| 国产精品一区二| 精品一级视频| 国产精品www.| 国产精品乱码| 国产精品99久久免费| 国产精品成久久久久三级| av中文在线资源| 欧美激情国产精品| 黄色网页网址在线免费| 国产一区二区三区丝袜| 日本福利午夜视频在线| 日韩精品极品在线观看| 五月天婷婷社区| 日韩欧美激情在线| 国产成人麻豆精品午夜在线| 欧美久久久久免费| 亚洲天堂一二三| 欧美三级在线播放| 国产99免费视频| 色悠悠亚洲一区二区| 男人午夜免费视频| 欧美午夜精品久久久久久久| 日韩福利片在线观看| 香港成人在线视频| 日本一区二区不卡在线| 亚洲成人免费视| 国产精品美女毛片真酒店| 亚洲 欧美综合在线网络| 国产在线观看免费视频今夜| 一区二区三区精品在线观看| 青娱乐国产盛宴| 亚洲制服丝袜av| 久久久久久久久久综合| 午夜久久久影院| 狠狠躁夜夜躁人人爽天天高潮| 婷婷亚洲久悠悠色悠在线播放| 日本一区二区免费在线观看| 岛国av一区二区三区| 日韩美一区二区| 1区2区3区在线| 97在线观看免费| 日韩精品av| 国产成人激情视频| 黄色成人小视频| 亚洲综合社区网| 福利在线一区| 欧洲亚洲一区| 天天做综合网| 亚洲欧美制服丝袜| 可以直接在线观看的av| 正在播放国产一区| www免费视频观看在线| 久久久久久久久久久久久久久久久久av| 精精国产xxxx视频在线中文版| 国产91精品黑色丝袜高跟鞋| 日日av拍夜夜添久久免费| 国产美女精品视频免费观看| 一区二区视频| 欧美日韩中文国产一区发布| 99久久99久久精品国产片果冰| 国产成人免费高清视频| 亚洲每日更新| 制服丝袜综合网| 国产大陆精品国产| 中字幕一区二区三区乱码| 最新国产の精品合集bt伙计| 国产成人啪精品午夜在线观看| 在线观看91精品国产入口| 国产精品永久久久久久久久久| 亚洲电影天堂av| 成人精品福利| 久久免费福利视频| 国产黄色精品| 精品国产免费一区二区三区| 久久高清精品| 国产成人在线免费看| 久国产精品韩国三级视频| 97人妻天天摸天天爽天天| 亚洲欧美综合网| 日本免费在线观看视频| 制服丝袜国产精品| 国产在线视频资源| 久久久久中文字幕2018| 欧美va在线| 狠狠色综合色区| 一区二区国产在线| 密臀av一区二区三区| 成人免费毛片app| 尤物在线免费视频| 欧美视频第二页| 少妇人妻精品一区二区三区| 久久亚洲成人精品| 亚洲伦乱视频| 久久99精品国产99久久| 一区二区不卡| 91pony九色| 国产嫩草影院久久久久| 视频一区二区三区四区五区| 精品国产99国产精品| 美女免费久久| 国产精品视频自在线| 偷窥自拍亚洲色图精选| 久久成人福利视频| 国产成人免费视频一区| 国产第一页浮力| 欧美日韩成人高清| 色综合久久影院| 琪琪第一精品导航| 老司机精品在线| 18禁网站免费无遮挡无码中文| 国产乱淫av一区二区三区| 欧美日韩国产黄色| 在线观看91精品国产入口| 国产在线播放av| 国产成人综合一区二区三区| 免费成人av| 久久久久久久久久久久久国产精品| 成人av第一页| 国产乡下妇女做爰视频| 欧美成人性福生活免费看| 影院在线观看全集免费观看| 91美女片黄在线观看游戏| 99精品在线观看| 制服丝袜中文字幕第一页 | 欧美成人精品3d动漫h| 国产视频中文字幕在线观看| 国产日产久久高清欧美一区| 成人免费av| 午夜天堂在线视频| 亚洲品质自拍视频| www.激情五月| 久久久免费精品视频| 秋霞蜜臀av久久电影网免费| 国产黄页在线观看| 久久夜色精品一区| 极品国产91在线网站| 最近2019中文字幕mv免费看| 日韩久久99| 毛片在线视频观看| 99久久伊人久久99| 免费av网站在线| 中文字幕日本精品| 日本少妇精品亚洲第一区| 国产午夜精品视频一区二区三区| 成人免费看视频| 麻豆成人免费视频| www.亚洲天堂| 18国产精品| 99久久国产宗和精品1上映| 欧美韩国日本综合| 精品人妻aV中文字幕乱码色欲| 欧美极品欧美精品欧美视频| 婷婷成人综合| www.日本一区| 亚洲在线视频网站| 九色在线免费| 成人写真福利网| 日韩午夜免费视频| 精品人体无码一区二区三区| 日韩片之四级片| 国模套图日韩精品一区二区| 欧美少妇一级片| 97se亚洲国产综合自在线| 中文字幕日日夜夜| 欧美激情综合色综合啪啪五月| 四虎5151久久欧美毛片| 手机av在线网| 精品国产91乱高清在线观看| 波多野结衣在线网站| 国产精品二区三区| 日韩成人午夜精品| 毛片aaaaa| 深夜福利一区二区| 日韩深夜福利| 91香蕉视频免费看| 色呦呦国产精品| www.51av欧美视频| 干日本少妇视频| 久久久久国产成人精品亚洲午夜 | 电影久久久久久|