返回按钮不触发带有位置作为依赖项的 useEffect。

huangapple go评论66阅读模式
英文:

Back Button doesn't fire useEffect with location as dependency

问题

On pressing back button of browser the useEffect doesn't fire although the location is being changed. Redirecting url using window.open() doesn't fire a change in this useEffect once I press back button and return to page from where I was redirected.

const location = useLocation();

useEffect(() => {
  // something that needs to run when there is a change in url

}, [location.pathname])

window.open(someUrl,"_self");

Things happening after window.open

  1. I am using SAML method to authenticate hence it redirects to a 3rd party server on logout
  2. Multiple redirects happen once 3rd party receives the logout request
  3. Once the logout is successful, I am redirected to my site from the server.
英文:

On pressing back button of browser the useEffect doesn't fire although the location is being changed. Redirecting url using window.open() doesn't fire a change in this useEffect once I press back button and return to page from where I was redirected.

const location = useLocation();

useEffect(() => {
  // something that needs to run when there is a change in url

}, [location.pathname])

window.open(someUrl,"_self");

Things happening after window.open

  1. I am using SAML method to authenticate hence it redirects to a 3rd party server on logout
  2. Multiple redirects happen once 3rd party receives the logout request
  3. Once the logout is successful, I am redirected to my site from the server.

答案1

得分: 2

useLocation钩子返回一个Location对象,具有以下接口:

export interface Path {
  pathname: string;
  search: string;
  hash: string;
}

export interface Location extends Path {
  state: any;
  key: string;
}

没有path属性。useEffect钩子应该使用location.pathname作为依赖项。

const location = useLocation();

useEffect(() => {
  // 需要在URL路径变化时运行的一些操作
}, [location.pathname]);

或者

const { pathname } = useLocation();

useEffect(() => {
  // 需要在URL路径变化时运行的一些操作
}, [pathname]);

演示

返回按钮不触发带有位置作为依赖项的 useEffect。


<details>
<summary>英文:</summary>

The `useLocation` hook returns a `Location` object with the following interface ([source][1]):

```typescript
export interface Path {
  pathname: string;
  search: string;
  hash: string;
}

export interface Location extends Path {
  state: any;
  key: string;
}

There is no path property. The useEffect hook should use location.pathname as the dependency.

const location = useLocation();

useEffect(() =&gt; {
  // something that needs to run when there is a change in url path
}, [location.pathname]);

or

const { pathname } = useLocation();

useEffect(() =&gt; {
  // something that needs to run when there is a change in url path
}, [pathname]);

Demo

返回按钮不触发带有位置作为依赖项的 useEffect。

huangapple
  • 本文由 发表于 2023年5月10日 13:33:12
  • 转载请务必保留本文链接:https://go.coder-hub.com/76215183.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定