V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
yuann72
V2EX  ›  前端开发

浏览器同时开两个网易云标签, A 标签开始播放, B 标签会自动暂停是如何实现的?

  •  
  •   yuann72 · 2021-03-22 22:48:30 +08:00 · 954 次点击
    这是一个创建于 1336 天前的主题,其中的信息可能已经有所发展或是发生改变。

    浏览器同时打开两个标签 https://music.163.com/
    B 标签播放音乐,A 标签也播放音乐,B 标签会自动暂停
    其中的原理是什么,两个标签之间是怎么通信的?

    3 条回复    2021-03-23 09:28:10 +08:00
    geelaw
        1
    geelaw  
       2021-03-22 22:54:25 +08:00 via iPhone   ❤️ 1
    不知道网易云怎么实现的,但想要实现还是很简单的,比如用 localStorage,每个页面打开的时候生成一个 GUID 并监听 localStorage 的变化。开始播放的时候设置 localStorage 里一项(比如 currentPlayer )为自己的 GUID ;如果这一项变化且变化后不是自己的 GUID 则暂停播放。
    yuann72
        2
    yuann72  
    OP
       2021-03-22 23:03:07 +08:00
    @geelaw 学到了,原来 localStorage 是可以监听的
    Misakas
        3
    Misakas  
       2021-03-23 09:28:10 +08:00
    浏览器提供了页面间通讯的 api [BroadcastChannel]( https://developer.mozilla.org/en-US/docs/Web/API/BroadcastChannel)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2498 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 15:45 · PVG 23:45 · LAX 07:45 · JFK 10:45
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.