首頁(yè)

WebSocket 百科

前端達(dá)人

WebSocket是一種在單個(gè)TCP連接上進(jìn)行全雙工通信的協(xié)議。WebSocket通信協(xié)議于2011年被IETF定為標(biāo)準(zhǔn)RFC 6455,并由RFC7936補(bǔ)充規(guī)范。WebSocket API也被W3C定為標(biāo)準(zhǔn)。
WebSocket使得客戶(hù)端和服務(wù)器之間的數(shù)據(jù)交換變得更加簡(jiǎn)單,允許服務(wù)端主動(dòng)向客戶(hù)端推送數(shù)據(jù)。在WebSocket API中,瀏覽器和服務(wù)器只需要完成一次握手,兩者之間就直接可以創(chuàng)建持久性的連接,并進(jìn)行雙向數(shù)據(jù)傳輸。
中文名
WebSocket
外文名
WebSocket
解    釋
基于TCP的全雙工通信協(xié)議
優(yōu)    點(diǎn)
服務(wù)器可以主動(dòng)傳送數(shù)據(jù)給客戶(hù)端
功    能
實(shí)現(xiàn)了瀏覽器與服務(wù)器全雙工通信

背景

 語(yǔ)音
很多網(wǎng)站為了實(shí)現(xiàn)推送技術(shù),所用的技術(shù)都是輪詢(xún)。輪詢(xún)是在特定的的時(shí)間間隔(如每1秒),由瀏覽器對(duì)服務(wù)器發(fā)出HTTP請(qǐng)求,然后由服務(wù)器返回最新的數(shù)據(jù)給客戶(hù)端的瀏覽器。這種傳統(tǒng)的模式帶來(lái)很明顯的缺點(diǎn),即瀏覽器需要不斷的向服務(wù)器發(fā)出請(qǐng)求,然而HTTP請(qǐng)求可能包含較長(zhǎng)的頭部,其中真正有效的數(shù)據(jù)可能只是很小的一部分,顯然這樣會(huì)浪費(fèi)很多的帶寬等資源。
而比較新的技術(shù)去做輪詢(xún)的效果是Comet。這種技術(shù)雖然可以雙向通信,但依然需要反復(fù)發(fā)出請(qǐng)求。而且在Comet中,普遍采用的長(zhǎng)鏈接,也會(huì)消耗服務(wù)器資源。
在這種情況下,HTML5定義了WebSocket協(xié)議,能更好的節(jié)省服務(wù)器資源和帶寬,并且能夠更實(shí)時(shí)地進(jìn)行通訊。

優(yōu)點(diǎn)

 語(yǔ)音
  • 較少的控制開(kāi)銷(xiāo)。在連接創(chuàng)建后,服務(wù)器和客戶(hù)端之間交換數(shù)據(jù)時(shí),用于協(xié)議控制的數(shù)據(jù)包頭部相對(duì)較小。在不包含擴(kuò)展的情況下,對(duì)于服務(wù)器到客戶(hù)端的內(nèi)容,此頭部大小只有2至10字節(jié)(和數(shù)據(jù)包長(zhǎng)度有關(guān));對(duì)于客戶(hù)端到服務(wù)器的內(nèi)容,此頭部還需要加上額外的4字節(jié)的掩碼。相對(duì)于HTTP請(qǐng)求每次都要攜帶完整的頭部,此項(xiàng)開(kāi)銷(xiāo)顯著減少了。
  • 更強(qiáng)的實(shí)時(shí)性。由于協(xié)議是全雙工的,所以服務(wù)器可以隨時(shí)主動(dòng)給客戶(hù)端下發(fā)數(shù)據(jù)。相對(duì)于HTTP請(qǐng)求需要等待客戶(hù)端發(fā)起請(qǐng)求服務(wù)端才能響應(yīng),延遲明顯更少;即使是和Comet等類(lèi)似的長(zhǎng)輪詢(xún)比較,其也能在短時(shí)間內(nèi)更多次地傳遞數(shù)據(jù)。
  • 保持連接狀態(tài)。與HTTP不同的是,Websocket需要先創(chuàng)建連接,這就使得其成為一種有狀態(tài)的協(xié)議,之后通信時(shí)可以省略部分狀態(tài)信息。而HTTP請(qǐng)求可能需要在每個(gè)請(qǐng)求都攜帶狀態(tài)信息(如身份認(rèn)證等)。
  • 更好的二進(jìn)制支持。Websocket定義了二進(jìn)制幀,相對(duì)HTTP,可以更輕松地處理二進(jìn)制內(nèi)容。
  • 可以支持?jǐn)U展。Websocket定義了擴(kuò)展,用戶(hù)可以擴(kuò)展協(xié)議、實(shí)現(xiàn)部分自定義的子協(xié)議。如部分瀏覽器支持壓縮等。
  • 更好的壓縮效果。相對(duì)于HTTP壓縮,Websocket在適當(dāng)?shù)臄U(kuò)展支持下,可以沿用之前內(nèi)容的上下文,在傳遞類(lèi)似的數(shù)據(jù)時(shí),可以顯著地提高壓縮率。

握手協(xié)議

 語(yǔ)音
WebSocket 是獨(dú)立的、創(chuàng)建在 TCP 上的協(xié)議。
Websocket 通過(guò)HTTP/1.1 協(xié)議的101狀態(tài)碼進(jìn)行握手。
為了創(chuàng)建Websocket連接,需要通過(guò)瀏覽器發(fā)出請(qǐng)求,之后服務(wù)器進(jìn)行回應(yīng),這個(gè)過(guò)程通常稱(chēng)為“握手”(handshaking)。


藍(lán)藍(lán)設(shè)計(jì)建立了UI設(shè)計(jì)分享群,每天會(huì)分享國(guó)內(nèi)外的一些優(yōu)秀設(shè)計(jì),如果有興趣的話,可以進(jìn)入一起成長(zhǎng)學(xué)習(xí),請(qǐng)掃碼ben_lanlan,報(bào)下信息,會(huì)請(qǐng)您入群。歡迎您加入噢~~希望得到建議咨詢(xún)、商務(wù)合作,也請(qǐng)與我們聯(lián)系。

分享此文一切功德,皆悉回向給文章原作者及眾讀者.
免責(zé)聲明:藍(lán)藍(lán)設(shè)計(jì)尊重原作者,文章的版權(quán)歸原作者。如涉及版權(quán)問(wèn)題,請(qǐng)及時(shí)與我們?nèi)〉寐?lián)系,我們立即更正或刪除。

藍(lán)藍(lán)設(shè)計(jì)sillybuy.com )是一家專(zhuān)注而深入的界面設(shè)計(jì)公司,為期望卓越的國(guó)內(nèi)外企業(yè)提供卓越的UI界面設(shè)計(jì)、BS界面設(shè)計(jì) 、 cs界面設(shè)計(jì) 、 ipad界面設(shè)計(jì) 、 包裝設(shè)計(jì) 、 圖標(biāo)定制 、 用戶(hù)體驗(yàn) 、交互設(shè)計(jì)、 網(wǎng)站建設(shè) 、平面設(shè)計(jì)服務(wù)


3D動(dòng)效設(shè)計(jì)小集

seo達(dá)人



 

原文地址:站酷
作者:FY印跡

 

轉(zhuǎn)載請(qǐng)注明:學(xué)UI網(wǎng)》3D動(dòng)效設(shè)計(jì)小集

藍(lán)藍(lán)設(shè)計(jì)建立了UI設(shè)計(jì)分享群,每天會(huì)分享國(guó)內(nèi)外的一些優(yōu)秀設(shè)計(jì),如果有興趣的話,可以進(jìn)入一起成長(zhǎng)學(xué)習(xí),請(qǐng)掃碼藍(lán)小助,報(bào)下信息,藍(lán)小助會(huì)請(qǐng)您入群。歡迎您加入噢~~希望得到建議咨詢(xún)、商務(wù)合作,也請(qǐng)與我們聯(lián)系。

截屏2021-05-13 上午11.41.03.png

分享此文一切功德,皆悉回向給文章原作者及眾讀者.
免責(zé)聲明:藍(lán)藍(lán)設(shè)計(jì)尊重原作者,文章的版權(quán)歸原作者。如涉及版權(quán)問(wèn)題,請(qǐng)及時(shí)與我們?nèi)〉寐?lián)系,我們立即更正或刪除。

藍(lán)藍(lán)設(shè)計(jì)sillybuy.com )是一家專(zhuān)注而深入的界面設(shè)計(jì)公司,為期望卓越的國(guó)內(nèi)外企業(yè)提供卓越的UI界面設(shè)計(jì)、BS界面設(shè)計(jì) 、 cs界面設(shè)計(jì) 、 ipad界面設(shè)計(jì) 、 包裝設(shè)計(jì) 、 圖標(biāo)定制 、 用戶(hù)體驗(yàn) 、交互設(shè)計(jì)、 網(wǎng)站建設(shè) 、平面設(shè)計(jì)服務(wù)



這些不同類(lèi)型的菜單圖標(biāo)和用法,我做了個(gè)總結(jié)分析!

seo達(dá)人


1.漢堡菜單

圖片

關(guān)鍵詞:橫條、多個(gè)菜單選項(xiàng)

這個(gè)圖標(biāo)的樣式簡(jiǎn)潔易懂,通常位于網(wǎng)頁(yè)和App的上下角,用來(lái)告知用戶(hù)這個(gè)按鈕之外還有更多內(nèi)容可以探索。

當(dāng)產(chǎn)品有多個(gè)菜單選項(xiàng)時(shí),考慮使用漢堡圖標(biāo)來(lái)顯示,但盡可能避免在桌面視圖中使用。

 

2.垂直三點(diǎn)式菜單

圖片

關(guān)鍵詞:垂直、內(nèi)嵌菜單

通常位于屏幕或窗口的右上角或頂部,是用于打開(kāi)帶有附加選項(xiàng)的圖標(biāo),打開(kāi)的內(nèi)容往往是一個(gè)較小的內(nèi)嵌菜單而不是整個(gè)全新的頁(yè)面。

 

3.水平三點(diǎn)式菜單

圖片

關(guān)鍵詞:水平、內(nèi)嵌菜單、web

水平三點(diǎn)式菜單同樣常位于屏幕或窗口的右上角,用于打開(kāi)菜單或顯示相關(guān)項(xiàng)的操作。

因?yàn)閳D標(biāo)樣式是水平的,所以更容易在web上或者在表格等水平方向中使用。

 

4.九宮格菜單 

圖片

關(guān)鍵詞:子分類(lèi)、子功能

九宮格菜單通常用于打開(kāi)同一產(chǎn)品中包含不同子產(chǎn)品或子功能,可以在它們之間快速切換,此圖標(biāo)常位于產(chǎn)品主頁(yè)的右上角。

 

5.過(guò)濾式菜單

圖片

關(guān)鍵詞:過(guò)濾、排序

過(guò)濾式菜單由三行不同長(zhǎng)度的線段水平疊放而成,是最廣泛使用的過(guò)濾符號(hào)??梢詫⑦^(guò)濾式菜單與“排序方式”選項(xiàng)結(jié)合使用,或者與全局過(guò)濾器結(jié)合使用。

 

6.漢堡菜單變體

圖片

關(guān)鍵詞:樣式特殊、時(shí)尚感更強(qiáng)

作為漢堡圖標(biāo)的替代品,與顯示列表菜單的目的相同嗎,但是這些樣式我們平常見(jiàn)的可能會(huì)比較少,更常用在充滿(mǎn)現(xiàn)代感、時(shí)尚感和藝術(shù)感的網(wǎng)站上。

圖片

 

最后

不同的樣式可能代表著截然不同的設(shè)計(jì)目的,常思考這些小而精的細(xì)節(jié),是保證產(chǎn)品體驗(yàn)提升的關(guān)鍵。

 

參考:uxplanet.org/choose-correct-menu-icon-for-your-navigation-7ffc22df80ac

 

原文地址:Clip設(shè)計(jì)夾(公眾號(hào))

作者:Clippp

轉(zhuǎn)載請(qǐng)注明:學(xué)UI網(wǎng)》這些不同類(lèi)型的菜單圖標(biāo)和用法,我做了個(gè)總結(jié)分析!

藍(lán)藍(lán)設(shè)計(jì)建立了UI設(shè)計(jì)分享群,每天會(huì)分享國(guó)內(nèi)外的一些優(yōu)秀設(shè)計(jì),如果有興趣的話,可以進(jìn)入一起成長(zhǎng)學(xué)習(xí),請(qǐng)掃碼藍(lán)小助,報(bào)下信息,藍(lán)小助會(huì)請(qǐng)您入群。歡迎您加入噢~~希望得到建議咨詢(xún)、商務(wù)合作,也請(qǐng)與我們聯(lián)系。

截屏2021-05-13 上午11.41.03.png

分享此文一切功德,皆悉回向給文章原作者及眾讀者.
免責(zé)聲明:藍(lán)藍(lán)設(shè)計(jì)尊重原作者,文章的版權(quán)歸原作者。如涉及版權(quán)問(wèn)題,請(qǐng)及時(shí)與我們?nèi)〉寐?lián)系,我們立即更正或刪除。

藍(lán)藍(lán)設(shè)計(jì)sillybuy.com )是一家專(zhuān)注而深入的界面設(shè)計(jì)公司,為期望卓越的國(guó)內(nèi)外企業(yè)提供卓越的UI界面設(shè)計(jì)、BS界面設(shè)計(jì) 、 cs界面設(shè)計(jì) 、 ipad界面設(shè)計(jì) 、 包裝設(shè)計(jì) 、 圖標(biāo)定制 、 用戶(hù)體驗(yàn) 、交互設(shè)計(jì)、 網(wǎng)站建設(shè) 平面設(shè)計(jì)服務(wù)



日歷

鏈接

個(gè)人資料

存檔