如何在reactjs/nextjs中拆分URL



完整URl为/search-results?query=home+floor&categories=All+Categories。我想把它分成两部分,像这样/search-resultsquery=home+floor&categories=All+Categories。我需要url的第二部分。我怎么能做到这一点在reactjs/nextjs或在javascript?

使用window.location来实现:

var path = window.location.pathname; //should be /search-result
var queryString = substr(window.location.search, 1); //should be  query=home+floor&categories=All+Categories

编辑:在Next.js你也可以使用next/router(在一个React组件)

import { useRouter } from 'next/router'
// in component
const router = useRouter();
const {pathname, query} = router; //pathname and query are what you are looking for.

您可以简单地对字符串使用.split()函数,通过"?"字符分割:

let uri = "/search-results?query=home+floor&categories=All+Categories";
let parts = uri.split("?");
let path = parts[0]; // "/search-results"
let query = parts[1]; // "query=home+floor&categories=All+Categories"

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/split

当在next.js应用程序中使用位置时,通常最好使用内置的router钩子。虽然依赖window可以用于客户端渲染,但当next.js在服务器端渲染某些内容时,您可能会遇到问题。

import { useRouter } from 'next/router'
function YourComponent() {
const router = useRouter()
const parts = router.asPath.split('?')
// ...
}

这将在paths变量中为您提供一个数组,其中paths[0]/search-results,paths[1]包含您的查询。但是,根据您的用例,使用router.query可能更好,因为它提供了已解析的查询部分。

next/router的文档其实很好。

最新更新