带你读《现代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

 

相关文章
|
18天前
|
JavaScript 前端开发 容器
AJAX载入外部JS文件到页面并让其执行的方法(附源码)
AJAX载入外部JS文件到页面并让其执行的方法(附源码)
18 0
|
22天前
|
前端开发 JavaScript 网络协议
前端最常见的JS面试题大全
【4月更文挑战第3天】前端最常见的JS面试题大全
45 5
|
1月前
|
JavaScript 前端开发 Java
springboot从控制器请求至页面时js失效的解决方法
springboot从控制器请求至页面时js失效的解决方法
15 0
springboot从控制器请求至页面时js失效的解决方法
|
1月前
|
JavaScript 前端开发 Java
纯前端JS实现人脸识别眨眨眼张张嘴案例
纯前端JS实现人脸识别眨眨眼张张嘴案例
52 0
|
1月前
|
JSON JavaScript 前端开发
解决js中Long类型数据在请求与响应过程精度丢失问题(springboot项目中)
解决js中Long类型数据在请求与响应过程精度丢失问题(springboot项目中)
42 0
|
1月前
|
JavaScript 前端开发
springboot+layui从控制器请求至页面时js失效的解决方法
springboot+layui从控制器请求至页面时js失效的解决方法
16 0
|
1天前
|
JavaScript 前端开发 API
Node.js在前端的妙用:打造更出色的Web体验
Node.js在前端的妙用:打造更出色的Web体验
16 5
|
10天前
|
存储 缓存 前端开发
前端如何利用indexDB进行数据优化
使用IndexedDB作为浏览器内置的客户端数据库,用于存储大量数据和实现离线支持。它能缓存常用数据,减少服务器请求,提高用户体验。IndexedDB支持数据索引、复杂查询及版本管理,允许离线操作并同步到服务器。但需熟悉其异步API,可借助Dexie.js、localForage等库简化使用。
|
19天前
|
JavaScript 前端开发
EasyUi js 加载数据表格DataGrid
EasyUi js 加载数据表格DataGrid
|
25天前
|
人工智能 前端开发 JavaScript
【前端设计】HTML+CSS+JavaScript基本特性
【前端设计】HTML+CSS+JavaScript基本特性