React 中的即时 real-time 通知
Instant real-time notifications in React
我目前正在开发基于 MERN 堆栈的 React 应用程序,我有一个用例,我想在该应用程序中实现即时通知。
例如,我有一个购物车,其中的商品在用户“adds to the cart
”时添加到 localstorage
并从 localstorage
中提取,并且在用户需要查看时显示给用户。我需要实现的是,显示一个徽章(如图所示),其中包含购物车中的商品数量。
根据我的研究,我发现不可能在同一个选项卡中监视和触发与 localstorage 相关的事件,这意味着这不是理想的解决方案。我需要在用户添加到购物车后立即更新徽章。
这个用例的最佳选择是什么?有没有方便的方法在React中实现实时通知?
(请注意,此徽章在 header 上,它是一个单独的组件,'add to cart
' 在另一个组件中。)
您可以使用以下任一方法:利用 useState Hook 的功能组件或使用基于 class 的组件。在这个例子中,我利用一个包 'local-storage' 来获取本地存储中保存的项目。
import React, {useState} from 'react';
import ls from 'local-storage';
const Cart = () => {
const [numberOfCart, setNumberOfCart] = useState(0);
setNumberOfCart(ls.get('cart').length);
return (
<div>
<span>{numberOfCart}</span>
</div>
)
}
class Cart extends React.Component {
constructor() {
super();
this.state = {
numberOfCart: 0
}
}
componentDidMount() {
this.setState({ numberOfCart: ls('get').length })
}
render() {
return (
<div>
<span>{this.state.numberOfCart}</span>
</div>
);
}
}
我目前正在开发基于 MERN 堆栈的 React 应用程序,我有一个用例,我想在该应用程序中实现即时通知。
例如,我有一个购物车,其中的商品在用户“adds to the cart
”时添加到 localstorage
并从 localstorage
中提取,并且在用户需要查看时显示给用户。我需要实现的是,显示一个徽章(如图所示),其中包含购物车中的商品数量。
根据我的研究,我发现不可能在同一个选项卡中监视和触发与 localstorage 相关的事件,这意味着这不是理想的解决方案。我需要在用户添加到购物车后立即更新徽章。
这个用例的最佳选择是什么?有没有方便的方法在React中实现实时通知?
(请注意,此徽章在 header 上,它是一个单独的组件,'add to cart
' 在另一个组件中。)
您可以使用以下任一方法:利用 useState Hook 的功能组件或使用基于 class 的组件。在这个例子中,我利用一个包 'local-storage' 来获取本地存储中保存的项目。
import React, {useState} from 'react';
import ls from 'local-storage';
const Cart = () => {
const [numberOfCart, setNumberOfCart] = useState(0);
setNumberOfCart(ls.get('cart').length);
return (
<div>
<span>{numberOfCart}</span>
</div>
)
}
class Cart extends React.Component {
constructor() {
super();
this.state = {
numberOfCart: 0
}
}
componentDidMount() {
this.setState({ numberOfCart: ls('get').length })
}
render() {
return (
<div>
<span>{this.state.numberOfCart}</span>
</div>
);
}
}