Next.js: How to redirect?

Created on 9 Aug 2018  路  10Comments  路  Source: vercel/next.js

I try in _app

render(){
if(!auth) Router.push('login')
}

and got error

Error: No router instance found.
You should only use "next/router" inside the client side of your app.

how do redirect do right?

Most helpful comment

How redirecting can be so hard with nextjs >:(

All 10 comments

The wiki has an entry about this subject.

For a more _real world_ example, please see with-apollo-auth example.

From what I've seen you should post any future questions not related to actual _issues_ to Next's Spectrum Chat instead.

Cheers :tada:

@klujanrosas Your example doesnt work in my case

How redirecting can be so hard with nextjs >:(

Check the code of this module https://github.com/matthewmueller/next-redirect/ it's actually quite simple, you should redirect in getInitialProps to avoid rendering and fetching unnecessary data.

You could also replace https://github.com/matthewmueller/next-redirect/blob/master/index.js#L16 with a Router.replace to avoid a reload.

Maybe some details would be great, instead of just downvoting. Because the example works completely fine for me.

I believe this is a difference in getInitialProps signature for _app.js and normal pages

@sergiodxa @jgillich I am doing something very similar to the implementation in next-redirect but after initiating a redirect on the client (via window.location.href="" where the string is the redirect url), getInitialProps still returns and the page still tries to render briefly before the browser redirects. Do you see the same behavior? Any tips on preventing that behavior?

@klujanrosas how do you redirect with a dynamic route e.g. /blog/:postId?

I am not sure why this got closed when it clearly does not answer the question for so many people.

There HAS to be a way to do redirects outside getInitialProps. I am using relay and don't have the data I need to be able to determine the redirect until the component is partially loaded. At that point, I no longer have access to the router OR the window property, it seems.

Hey, all!

Issuing a side effect during rendering is not a standard React practice.
This can easily become problematic in many scenarios, especially if Next.js ever starts optimistically rendering hidden trees for navigation.

You should avoid redirecting client-side within getInitialProps for the same reason. While this pattern currently works in practice, the patterns listed below are more encouraged.

Redirects are a side effect, and should occur as so within your component's events:

componentDidMount() { // and/or componentDidUpdate, depending on what you're trying to do
  if (!auth) {
    Router.push('...')
  }
}

render() {
  if (!auth) {
    return null;
  }
  // ...
}

For a functional component:

function MyPage() {
  useEffect(() => {
    if (!auth) {
      Router.push('...')
    }
  })

  // ...
}

Please open a new thread on our Spectrum if you have any questions or need guidance.

Was this page helpful?
0 / 5 - 0 ratings

Related issues

pie6k picture pie6k  路  3Comments

swrdfish picture swrdfish  路  3Comments

jesselee34 picture jesselee34  路  3Comments

timneutkens picture timneutkens  路  3Comments

renatorib picture renatorib  路  3Comments