浏览器新标签页新增/修改数据时,列表页实时刷新--监听本地存储

文章介绍了在JavaScript中创建的util.js模块,该模块包含两个功能函数:sendMsg用于存储特定类型的数据到localStorage,而listenMsg用于监听并处理localStorage中的变化,实现Web页面间的数据同步。在页面挂载和卸载时分别调用这两个函数,以实现在新增或编辑数据操作完成后通知列表页更新。
摘要由CSDN通过智能技术生成
新建util.js
export function sendMsg(type,payload){
	localStorage.setItem(
		'@@' + type,
		JSON.stringify({
			payload,
			temp: Date.now(),
		})
	)
}

export function listenMsg(handler) {
	const storageHandler = (e) => {
		const data = JSON.parse(e.newValue);
		handler(e.key.subString(2),data.payload);
		};
		window.addEventListener('storage',storageHandler);
		return () => {
			window.removeEventListener('storage',storageHandler);
		  };
}
------------------------列表页 数据加载完成时 监听消息------------------------
let unHandler;
mounted: function() {
	// 监听消息
	listenMsg((type, payload)=>{
		console.log(type,payload)
	})
}

onUnmounted(()=>{
  // 取消监听
	unHandler && unHandler();
})
------------------------新增/修改页面 操作完成时 发送消息------------------------
sendMsg('add-emp',新增数据消息对象);
sendMsg('edit-emp',修改数据消息对象);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值