带你读《现代Javascript高级教程》二十一、前端跨页面通信:实现页面间的数据传递与交互(2)

简介: 带你读《现代Javascript高级教程》二十一、前端跨页面通信:实现页面间的数据传递与交互(2)

带你读《现代Javascript高级教程》二十一、前端跨页面通信:实现页面间的数据传递与交互(1)https://developer.aliyun.com/article/1349531?groupCode=tech_library


4. 前端跨页面通信的实现方法

在前端中,有多种方法可以实现跨页面通信。下面介绍几种常用的实现方法:

1 Cookie

Cookie是一种在浏览器中存储数据的机制,可以通过设置Cookie的值在不同页面之间传递数据。通过设置相同的Cookie名称和值,不同的页面可以读取和修改Cookie的值,实现跨页面数据的传递和共享。

 

使用Cookie进行跨页面通信的示例代码如下:

 

// 在页面 A 中设置 Cookie
document.cookie = "data=example";
// 在页面 B 中读取 Cookieconst cookies = document.cookie.split("; ");for (let i = 0; i < cookies.length; i++) {
  const [name, value] = cookies[i].split("=");
  if (name === "data") {
    console.log(value); // 输出 "example"
    break;
  }}

2 LocalStorage 和 SessionStorage

LocalStorage和SessionStorage是浏览器提供的本地存储机制,可以在不同页面之间存储和读取数据。它们的区别在于数据的生命周期,LocalStorage中的数据在浏览器关闭后仍然保留,而SessionStorage中的数据在会话结束后被清除。

 

使用LocalStorage进行跨页面通信的示例代码如下:

 

// 在页面 A 中存储数据到 LocalStorage
localStorage.setItem("data", "example");
// 在页面 B 中读取 LocalStorage 的数据const data = localStorage.getItem("data");
console.log(data); // 输出 "example"

3 Broadcast Channel

Broadcast Channel是浏览器提供的API,用于在不同页面之间进行消息广播和接收。通过Broadcast Channel,我们可以创建一个频道,并在不同的页面之间发送和接收消息。

 

使用Broadcast Channel进行跨页面通信的示例代码如下:

 

// 在页面 A 中创建 Broadcast Channelconst channel = new BroadcastChannel("myChannel");
// 在页面 B 中监听消息
channel.addEventListener("message", (event) => {
  console.log(event.data); // 输出接收到的消息});
// 在页面 A 中发送消息
channel.postMessage("Hello from Page A");

4 Window.postMessage

Window.postMessage是浏览器提供的API,用于在不同窗口或框架之间进行安全的跨页面通信。通过Window.postMessage,我们可以向其他窗口发送消息,并接收其他窗口发送的消息。

 

使用Window.postMessage进行跨页面通信的示例代码如下:

// 在页面 A 中发送消息给页面 B
window.opener.postMessage("Hello from Page A", "https://www.example.com");
// 在页面 B 中监听消息
window.addEventListener("message", (event) => {
  if (event.origin === "https://www.example.com") {
    console.log(event.data); // 输出接收到的消息
  }});

5. 参考资料

  • MDN Web Docs - Window.postMessage()open in new window
  • MDN Web Docs - BroadcastChannelopen in new window
  • MDN Web Docs - Cookieopen in new window
  • MDN Web Docs - Web Storage APIopen in new window
  • Using the Broadcast Channel API for JavaScript communication between tabsopen in new window
  • Cross-window communication using postMessageopen in new window
  • Window Communication in JavaScript: A Comprehensive Guide

 

相关文章
|
16天前
|
前端开发 数据可视化 JavaScript
前端vite+vue3——可视化页面性能耗时指标(fmp、fp)
前端vite+vue3——可视化页面性能耗时指标(fmp、fp)
40 6
|
5天前
|
Web App开发 JavaScript 前端开发
《手把手教你》系列技巧篇(三十九)-java+ selenium自动化测试-JavaScript的调用执行-上篇(详解教程)
【5月更文挑战第3天】本文介绍了如何在Web自动化测试中使用JavaScript执行器(JavascriptExecutor)来完成Selenium API无法处理的任务。首先,需要将WebDriver转换为JavascriptExecutor对象,然后通过executeScript方法执行JavaScript代码。示例用法包括设置JS代码字符串并调用executeScript。文章提供了两个实战场景:一是当时间插件限制输入时,用JS去除元素的readonly属性;二是处理需滚动才能显示的元素,利用JS滚动页面。还给出了一个滚动到底部的代码示例,并提供了详细步骤和解释。
28 10
|
2天前
|
存储 JavaScript 前端开发
Javascript教程
Javascript教程
7 0
|
4天前
|
JavaScript 前端开发 Java
《手把手教你》系列技巧篇(四十)-java+ selenium自动化测试-JavaScript的调用执行-下篇(详解教程)
【5月更文挑战第4天】本文介绍了如何使用JavaScriptExecutor在自动化测试中实现元素高亮显示。通过创建并执行JS代码,可以改变元素的样式,例如设置背景色和边框,以突出显示被操作的元素。文中提供了一个Java示例,展示了如何在Selenium中使用此方法,并附有代码截图和运行效果展示。该技术有助于跟踪和理解测试过程中的元素交互。
8 0
|
10天前
|
JSON JavaScript Java
从前端Vue到后端Spring Boot:接收JSON数据的正确姿势
从前端Vue到后端Spring Boot:接收JSON数据的正确姿势
22 0
|
12天前
|
开发框架 前端开发 Android开发
【Flutter 前端技术开发专栏】Flutter 与原生模块通信机制
【4月更文挑战第30天】本文探讨了Flutter作为跨平台开发框架与原生Android和iOS交互的必要性,主要通过方法调用和事件传递实现。文中详细介绍了Flutter与Android/iOS的通信方式,数据传输(包括基本和复杂类型),性能优化,错误处理以及实际应用案例。理解并掌握这一通信机制对开发高质量移动应用至关重要,未来有望随着技术发展得到进一步优化。
【Flutter 前端技术开发专栏】Flutter 与原生模块通信机制
|
13天前
|
机器学习/深度学习 前端开发 数据可视化
数据分析web可视化神器---streamlit框架,无需懂前端也能搭建出精美的web网站页面
数据分析web可视化神器---streamlit框架,无需懂前端也能搭建出精美的web网站页面
|
26天前
|
存储 缓存 前端开发
前端如何利用indexDB进行数据优化
使用IndexedDB作为浏览器内置的客户端数据库,用于存储大量数据和实现离线支持。它能缓存常用数据,减少服务器请求,提高用户体验。IndexedDB支持数据索引、复杂查询及版本管理,允许离线操作并同步到服务器。但需熟悉其异步API,可借助Dexie.js、localForage等库简化使用。
|
26天前
|
存储 前端开发 API
对象存储OSS产品常见问题之获取文件结构并在前端页面展示如何解决
对象存储OSS是基于互联网的数据存储服务模式,让用户可以安全、可靠地存储大量非结构化数据,如图片、音频、视频、文档等任意类型文件,并通过简单的基于HTTP/HTTPS协议的RESTful API接口进行访问和管理。本帖梳理了用户在实际使用中可能遇到的各种常见问题,涵盖了基础操作、性能优化、安全设置、费用管理、数据备份与恢复、跨区域同步、API接口调用等多个方面。
27 0
|
29天前
|
JavaScript 前端开发
JavaScript高级主题:什么是 ES6 的解构赋值?
【4月更文挑战第13天】ES6的解构赋值语法简化了从数组和对象中提取值的过程,提高代码可读性。例如,可以从数组`[1, 2, 3]`中分别赋值给`a`, `b`, `c`,或者从对象`{x: 1, y: 2, z: 3}`中提取属性值给同名变量。
18 6