我如何从一个ReactJS组件中获得完整的URL ?

我认为它应该是这样的。props。location但它是未定义的


当前回答

正如其他人提到的,首先你需要一个反应路由器包。但它提供给你的location对象包含解析过的url。

但是如果你想要完整的url没有访问全局变量,我相信最快的方法是这样做

...

const getA = memoize(() => document.createElement('a'));
const getCleanA = () => Object.assign(getA(), { href: '' });

const MyComponent = ({ location }) => {
  const { href } = Object.assign(getCleanA(), location);

  ...

Href包含一个完整的url。

记住,我通常使用lodash,它的实现方式主要是为了避免不必要地创建新元素。

注:当然,你不受古老浏览器的限制,你可能想尝试新的URL()东西,但基本上整个情况或多或少是毫无意义的,因为你访问全局变量的一种或另一种方式。那么为什么不使用window.location.href呢?

其他回答

正如其他人提到的,首先你需要一个反应路由器包。但它提供给你的location对象包含解析过的url。

但是如果你想要完整的url没有访问全局变量,我相信最快的方法是这样做

...

const getA = memoize(() => document.createElement('a'));
const getCleanA = () => Object.assign(getA(), { href: '' });

const MyComponent = ({ location }) => {
  const { href } = Object.assign(getCleanA(), location);

  ...

Href包含一个完整的url。

记住,我通常使用lodash,它的实现方式主要是为了避免不必要地创建新元素。

注:当然,你不受古老浏览器的限制,你可能想尝试新的URL()东西,但基本上整个情况或多或少是毫无意义的,因为你访问全局变量的一种或另一种方式。那么为什么不使用window.location.href呢?

Window.location.href是你要找的。

为了获得当前路由器实例或当前位置,你必须从react-router-dom中使用withRouter创建一个高级组件。否则,当你试图访问this.props.location时,它将返回undefined

例子

import React, { Component } from 'react';
import { withRouter } from 'react-router-dom';

class className extends Component {

      render(){
           return(
                ....
                  )
              }
}

export default withRouter(className)

location是一个react-router特性,如果你想使用它,你必须安装它。

注意:不返回完整的url。

Window.location.href是你需要的。但是如果你正在使用react路由器,你可能会发现检查useLocation和useHistory钩子很有用。 这两种方法都创建了一个具有pathname属性的对象,你可以读取它,而且对很多其他事情都很有用。这是一个youtube视频,解释了react路由器钩子

两者都会给你你所需要的(没有域名):

import { useHistory ,useLocation } from 'react-router-dom';
const location = useLocation()
location.pathname

const history = useHistory()
history.location.pathname