React useHash钩子
跟踪浏览器的位置哈希值,并允许更改它。
- 使用
useState()
钩子来惰性获取Location
对象的hash
属性。 - 使用
useCallback()
钩子创建一个更新状态的处理程序。 - 使用
useEffect()
钩子在挂载时添加一个监听器来监听'hashchange'
事件,并在卸载时清理它。 - 使用
useCallback()
钩子创建一个函数,用给定的值更新Location
对象的hash
属性。
const useHash = () => {
const [hash, setHash] = React.useState(() => window.location.hash);
const hashChangeHandler = React.useCallback(() => {
setHash(window.location.hash);
}, []);
React.useEffect(() => {
window.addEventListener('hashchange', hashChangeHandler);
return () => {
window.removeEventListener('hashchange', hashChangeHandler);
};
}, []);
const updateHash = React.useCallback(
newHash => {
if (newHash !== hash) window.location.hash = newHash;
},
[hash]
);
return [hash, updateHash];
};
const MyApp = () => {
const [hash, setHash] = useHash();
React.useEffect(() => {
setHash('#list');
}, []);
return (
<>
<p>window.location.href: {window.location.href}</p>
<p>编辑哈希值: </p>
<input value={hash} onChange={e => setHash(e.target.value)} />
</>
);
};
ReactDOM.createRoot(document.getElementById('root')).render(
<MyApp />
);