實現(xiàn)多個標簽頁之間通信的幾種方法(sharedworker)

效果圖.gif

prologue

  • 之前在網(wǎng)上看到一個面試題:如何實現(xiàn)瀏覽器中多個標簽頁之間的通信。我目前想到的方法有三種:使用websocket協(xié)議刃跛、通過localstorage膊夹、以及使用html5瀏覽器的新特性SharedWorker怔匣。
  • websocket這里先不介紹了,全雙工(full-duplex)通信自然可以實現(xiàn)多個標簽頁之間的通信,相信網(wǎng)上通過websocket實現(xiàn)聊天室的教程也不少苔严,我自己也用socket.io寫了一個在線聊天室.
  • 接下來會介紹另外兩個方法:監(jiān)聽localstorage和使用SharedWorker

localstorage

  • localstorage是瀏覽器多個標簽共用的存儲空間,所以可以用來實現(xiàn)多標簽之間的通信(ps:session是會話級的存儲空間孤澎,每個標簽頁都是單獨的)届氢。
  • 直接在window對象上添加監(jiān)聽即可:
window.onstorage = (e) => {console.log(e)}
// 或者這樣
window.addEventListener('storage', (e) => console.log(e))
  • onstorage以及storage事件,針對都是非當前頁面對localStorage進行修改時才會觸發(fā)覆旭,當前頁面修改localStorage不會觸發(fā)監(jiān)聽函數(shù)退子。然后就是在對原有的數(shù)據(jù)的值進行修改時才會觸發(fā)岖妄,比如原本已經(jīng)有一個key會a值為b的localStorage,你再執(zhí)行:localStorage.setItem('a', 'b')代碼寂祥,同樣是不會觸發(fā)監(jiān)聽函數(shù)的荐虐。

webworker

  • 我們都知道JavaScript是單線程的,但是瀏覽器是擁有過個線程的比如:gui渲染線程丸凭、JS引擎線程福扬、事件觸發(fā)線程、異步http請求線程惜犀。
  • webworker作為瀏覽器的一個新特性忧换,可以提供一個額外的線程來執(zhí)行一些js代碼,并且不會影響到瀏覽器用戶界面向拆。
  • 應用場景:比如頁面中包含耗時較大的算法代碼時亚茬,就會阻塞線程影響瀏覽器渲染等等。這時候就可把耗時代碼浓恳,放到webworker(另一個線程)中執(zhí)行刹缝。
  • 注意,這種多線程能力不是JavaScript語言原生具有的颈将,而是瀏覽器宿主環(huán)境提供的梢夯。
  • 普通的webworker直接使用new Worker()即可創(chuàng)建,這種webworker是當前頁面專有的晴圾。然后還有種共享worker(SharedWorker)颂砸,這種是可以多個標簽頁、iframe共同使用的死姚,接下來介紹如何使用SharedWorker實現(xiàn)標簽頁之間的通信人乓。

SharedWorker

  • SharedWorker可以被多個window共同使用,但必須保證這些標簽頁都是同源的(相同的協(xié)議都毒,主機和端口號)
  • 首先新建一個js文件worker.js色罚,具體代碼如下:
// sharedWorker所要用到的js文件,不必打包到項目中账劲,直接放到服務器即可
let data = ''
onconnect = function (e) {
  let port = e.ports[0]

  port.onmessage = function (e) {
    if (e.data === 'get') {
      port.postMessage(data)
    } else {
      data = e.data
    }
  }
}
  • webworker端(暫且這樣稱呼)的代碼就如上戳护,只需注冊一個onmessage監(jiān)聽信息的事件,客戶端(即使用sharedWorker的標簽頁)發(fā)送message時就會觸發(fā)瀑焦。

  • 注意webworker無法在本地使用腌且,出于瀏覽器本身的安全機制,所以我這次的示例也是放在服務器上的榛瓮,worker.jsindex.html在同一目錄铺董。

    image

  • 因為客戶端和webworker端的通信不像websocket那樣是全雙工的,所以客戶端發(fā)送數(shù)據(jù)和接收數(shù)據(jù)要分成兩步來處理榆芦。示例中會有兩個按鈕柄粹,分別對應的向sharedWorker發(fā)送數(shù)據(jù)的請求以及獲取數(shù)據(jù)的請求喘鸟,但他們本質(zhì)上都是相同的事件--發(fā)送消息。

  • webworker端會進行判斷驻右,傳遞的數(shù)據(jù)為'get'時什黑,就把變量data的值回傳給客戶端,其他情況堪夭,則把客戶端傳遞過來的數(shù)據(jù)存儲到data變量中愕把。下面是客戶端的代碼:

// 這段代碼是必須的,打開頁面后注冊SharedWorker森爽,顯示指定worker.port.start()方法建立與worker間的連接
    if (typeof Worker === "undefined") {
      alert('當前瀏覽器不支持webworker')
    } else {
      let worker = new SharedWorker('worker.js')
      worker.port.addEventListener('message', (e) => {
        console.log('來自worker的數(shù)據(jù):', e.data)
      }, false)
      worker.port.start()
      window.worker = worker
    }
// 獲取和發(fā)送消息都是調(diào)用postMessage方法恨豁,我這里約定的是傳遞'get'表示獲取數(shù)據(jù)。
window.worker.port.postMessage('get')
window.worker.port.postMessage('發(fā)送信息給worker')
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末计福,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子徽职,更是在濱河造成了極大的恐慌象颖,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,406評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件姆钉,死亡現(xiàn)場離奇詭異说订,居然都是意外死亡,警方通過查閱死者的電腦和手機潮瓶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,395評論 3 398
  • 文/潘曉璐 我一進店門陶冷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人筋讨,你說我怎么就攤上這事埃叭∶校” “怎么了悉罕?”我有些...
    開封第一講書人閱讀 167,815評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長立镶。 經(jīng)常有香客問我壁袄,道長,這世上最難降的妖魔是什么媚媒? 我笑而不...
    開封第一講書人閱讀 59,537評論 1 296
  • 正文 為了忘掉前任嗜逻,我火速辦了婚禮,結(jié)果婚禮上缭召,老公的妹妹穿的比我還像新娘栈顷。我一直安慰自己逆日,他們只是感情好,可當我...
    茶點故事閱讀 68,536評論 6 397
  • 文/花漫 我一把揭開白布萄凤。 她就那樣靜靜地躺著室抽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪靡努。 梳的紋絲不亂的頭發(fā)上坪圾,一...
    開封第一講書人閱讀 52,184評論 1 308
  • 那天,我揣著相機與錄音惑朦,去河邊找鬼兽泄。 笑死,一個胖子當著我的面吹牛漾月,可吹牛的內(nèi)容都是我干的病梢。 我是一名探鬼主播,決...
    沈念sama閱讀 40,776評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼梁肿,長吁一口氣:“原來是場噩夢啊……” “哼飘千!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起栈雳,我...
    開封第一講書人閱讀 39,668評論 0 276
  • 序言:老撾萬榮一對情侶失蹤护奈,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后哥纫,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體霉旗,經(jīng)...
    沈念sama閱讀 46,212評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,299評論 3 340
  • 正文 我和宋清朗相戀三年蛀骇,在試婚紗的時候發(fā)現(xiàn)自己被綠了厌秒。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,438評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡擅憔,死狀恐怖鸵闪,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情暑诸,我是刑警寧澤蚌讼,帶...
    沈念sama閱讀 36,128評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站个榕,受9級特大地震影響篡石,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜西采,卻給世界環(huán)境...
    茶點故事閱讀 41,807評論 3 333
  • 文/蒙蒙 一凰萨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦胖眷、人聲如沸武通。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,279評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽厅须。三九已至,卻和暖如春食棕,著一層夾襖步出監(jiān)牢的瞬間朗和,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,395評論 1 272
  • 我被黑心中介騙來泰國打工簿晓, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留眶拉,地道東北人。 一個月前我還...
    沈念sama閱讀 48,827評論 3 376
  • 正文 我出身青樓憔儿,卻偏偏與公主長得像忆植,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子谒臼,可洞房花燭夜當晚...
    茶點故事閱讀 45,446評論 2 359

推薦閱讀更多精彩內(nèi)容