如何实现网页多标签tab通讯?

  • 通过websocket
    • 无跨域限制
    • 需要服务端支持,成本高
  • 通过localStorage同域通讯(推荐)
    • 同域AB两个页面
    • A页面设置localStorage
    • B页面可监听到localStorage值的修改
  • 通过SharedWorker通讯
    • SharedWorkerWebWorker的一种
    • WebWorker可开启子进程执行JS,但不能操作DOM
    • SharedWorker可单独开启一个进程,用于同域页面通讯
    • SharedWorker兼容性不太好,调试不方便,IE11不支持

localStorage通讯例子

<!-- 列表页 -->
<p>localStorage message - list page</p>

<script>
  // 监听storage事件
  window.addEventListener('storage', event => {
    console.info('key', event.key)
    console.info('value', event.newValue)
  })
</script>

<!-- 详情页 -->
<p>localStorage message - detail page</p>

<button id="btn1">修改标题</button>

<script>
  const btn1 = document.getElementById('btn1')
  btn1.addEventListener('click', () => {
    const newInfo = {
      id: 100,
      name: '标题' + Date.now()
    }
    localStorage.setItem('changeInfo', JSON.stringify(newInfo))
  })

  // localStorage 跨域不共享
</script>

SharedWorker通讯例子

本地调试的时候打开chrome隐私模式验证,如果没有收到消息,打开chrome://inspect/#workers => sharedWorkers => 点击inspect

<p>SharedWorker message - list page</p>

<script>
  const worker = new SharedWorker('./worker.js')
  worker.port.onmessage = e => console.info('list', e.data)
</script>

<p>SharedWorker message - detail page</p>
<button id="btn1">修改标题</button>

<script>
  const worker = new SharedWorker('./worker.js')

  const btn1 = document.getElementById('btn1')
  btn1.addEventListener('click', () => {
    console.log('clicked')
    worker.port.postMessage('detail go...')
  })
</script>

// worker.js

/**
 * @description for SharedWorker
 */

const set = new Set()

onconnect = event => {
  const port = event.ports[0]
  set.add(port)

  // 接收信息
  port.onmessage = e => {
    // 广播消息
    set.forEach(p => {
      if (p === port) return // 不给自己广播
      p.postMessage(e.data)
    })
  }

  // 发送信息
  port.postMessage('worker.js done')
}

如何实现网页和iframe之间的通讯 ?

  • 使用postMessage通信
  • 注意跨域的限制和判断,判断域名的合法性

演示

<!-- 首页 -->
<p>
  index page
  <button id="btn1">发送消息</button>
</p>

<iframe id="iframe1" src="./child.html"></iframe>

<script>
  document.getElementById('btn1').addEventListener('click', () => {
    console.info('index clicked')
    window.iframe1.contentWindow.postMessage('hello', '*') // * 没有域名限制
  })

  // 接收child的消息
  window.addEventListener('message', event => {
    console.info('origin', event.origin) // 来源的域名
    console.info('index received', event.data)
  })
</script>

<!-- 子页面 -->
<p>
  child page
  <button id="btn1">发送消息</button>
</p>

<script>
  document.getElementById('btn1').addEventListener('click', () => {
    console.info('child clicked')
    // child被嵌入到index页面,获取child的父页面
    window.parent.postMessage('world', '*') // * 没有域名限制
  })

  // 接收parent的消息
  window.addEventListener('message', event => {
    console.info('origin', event.origin) // 判断 origin 的合法性
    console.info('child received', event.data)
  })
</script>

效果

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用`tkinter`库实现两个Tab页面,可以使用`ttk`模块中的`Notebook`小部件。`Notebook`提供了一个选项卡布局,可以轻松切换不同的页面。以下是一个使用`Notebook`实现两个Tab页面的示例代码: ```python import tkinter as tk from tkinter import ttk def on_tab_selected(event): selected_tab = event.widget.select() tab_text = event.widget.tab(selected_tab, "text") print(f"选中的选项卡: {tab_text}") root = tk.Tk() root.title("Tab示例") # 创建Notebook小部件 notebook = ttk.Notebook(root) notebook.pack(pady=10) # 创建第一个Tab页面 tab1 = ttk.Frame(notebook) notebook.add(tab1, text="Tab 1") label1 = ttk.Label(tab1, text="这是第一个Tab页面") label1.pack(pady=10) # 创建第二个Tab页面 tab2 = ttk.Frame(notebook) notebook.add(tab2, text="Tab 2") label2 = ttk.Label(tab2, text="这是第二个Tab页面") label2.pack(pady=10) notebook.bind("<<NotebookTabChanged>>", on_tab_selected) root.mainloop() ``` 在上面的代码中,我们首先创建了一个`Notebook`小部件,并将其放置在主窗口中。然后,我们使用`add()`方法添加两个Tab页面到`Notebook`中,并为每个Tab页面设置一个文本标签。 在每个Tab页面中,我们可以添加其他的`tkinter`小部件来构建页面内容。例如,上面的示例中,我们在每个Tab页面中添加了一个`Label`小部件。 我们还通过绑定`<<NotebookTabChanged>>`事件来捕获用户切换选项卡的动作,并在回调函数`on_tab_selected`中打印选中的选项卡文本。 请注意,这只是一个基本示例,您可以根据实际需求进行更复杂的布局和功能扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值