Welcome to OStack Knowledge Sharing Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
448 views
in Technique[技术] by (71.8m points)

express - 在next.js中获取客户端的当前URL(Getting the current url on the client side in next.js)

So I am working on a nodejs app which I will have my new website on and I want to make a way for my user on the clientside to display different things, re-renderd depending on what the user is pressing on.

(因此,我正在开发一个nodejs应用程序,该应用程序将打开我的新网站,我想为我的用户提供一种方法,使其在客户端显示不同的内容,并根据用户所按下的内容进行重新渲染。)

My idea is that for example firstly the user would see "Please select a tool first" and then the user will select a tool in the navbar which then the page will be re-renderd and display the tool selected inside a jumbotron with the url being changed for example then /admin/[ToolSelected].

(我的想法是,例如,首先用户将看到“请先选择一个工具”,然后用户将在导航栏中选择一个工具,然后该页面将被重新渲染并显示在超大屏幕内部选定的工具,其网址为例如,先更改为/ admin / [ToolSelected]。)

The only thing is tho that I do not know how to achive this.

(唯一的事情就是我不知道如何实现这一目标。)

I was thinking that the client side code could detect what the url is and is placed as a page variable then the tool will displayed with a IF statement depending on what the page variable is.

(我以为客户端代码可以检测到url是什么,并将其作为页面变量放置,然后根据页面变量是什么,该工具将显示IF语句。)

Would my theory work or how can a achive this in a efficent way?

(我的理论会行得通吗,或者如何有效地实现这一目标?)

Here is my main page code:

(这是我的主页代码:)

// Including Navbar and css
import AdminLayout from '../comps/admin/adminLayout'

// the so called "tools" more will exist in the future
import Passform from '../comps/admin/tools/passform'


// Fetching the current url the user is on
var page = CURRENT_URL;


const jumbotron = {
  background: 'white'
}

const Admin = (page) => (

  <AdminLayout>

  <style global jsx>
  {
    `body {
      background: #eff0f3;
    }`
  }
  </style>
    <div className="jumbotron" style={jumbotron}>

    {(page == "passform") ? (
      <Passform/>
    ) : (
      <h3>Something is wrong :/ . {page}</h3>
    )}

    </div>
  </AdminLayout>
)

export default Admin
  ask by Linus J translate from so

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Answer

0 votes
by (71.8m points)

You can wrap your component with withRouter HOC, that will inject the router object, that has current pathname .

(您可以使用withRouter HOC包装组件,这将注入具有当前pathnamerouter对象。)

import { withRouter } from 'next/router';

const Admin = ({ router }) => (
  <AdminLayout>
    <style global jsx>
      {`
        body {
          background: #eff0f3;
        }
      `}
    </style>
    <div className="jumbotron" style={jumbotron}>
      {router.pathname == 'passform' ? <Passform /> : <h3>Something is wrong :/ . {page}</h3>}
    </div>
  </AdminLayout>
);

export default withRouter(Admin);

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome to OStack Knowledge Sharing Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...