我得到这个错误:

Uncaught Error: Invariant Violation: Element type is invalid: expected a string (for built-in components) or a class/function (for composite components) but got: object.

这是我的代码:

var React = require('react')
var ReactDOM =  require('react-dom')
var Router = require('react-router')
var Route = Router.Route
var Link = Router.Link

var App = React.createClass({
  render() {
    return (
      <div>
        <h1>App</h1>
        <ul>
          <li><Link to="/about">About</Link></li>
        </ul>
      </div>
    )
  }
})

var About = require('./components/Home')
ReactDOM.render((
  <Router>
    <Route path="/" component={App}>
      <Route path="about" component={About} />
    </Route>
  </Router>
), document.body)

我的家。jsx文件:

var React = require('react');
var RaisedButton = require('material-ui/lib/raised-button');

var Home = React.createClass({
  render:function() {
    return (
        <RaisedButton label="Default" />
    );
  },
});

module.exports = Home;

您需要导出default或require(path).default

var About = require('./components/Home').default

https://github.com/rackt/react-router/blob/e7c6f3d848e55dda11595447928e843d39bed0eb/examples/query-params/app.js#L4 路由器也是react-router的属性之一。 所以改变你的模块需要这样的代码:

  var reactRouter = require('react-router')
  var Router = reactRouter.Router
  var Route = reactRouter.Route
  var Link = reactRouter.Link

如果你想使用ES6语法的链接使用(导入),使用babel作为助手。

顺便说一句,为了让你的代码正常工作,我们可以添加{this.props。children}在App中, 就像

render() {
  return (
    <div>
      <h1>App</h1>
      <ul>
        <li><Link to="/about">About</Link></li>
      </ul>
      {this.props.children}
    </div>

  )
}

你是否已经将React组件模块化了?如果是,如果忘记指定模块,就会得到这个错误。出口,例如:

非模块化以前有效的组件/代码:

var YourReactComponent = React.createClass({
    render: function() { ...

使用module.exports模块化组件/代码:

module.exports = React.createClass({
    render: function() { ...

在我的案例中(使用Webpack),这是以下两者的区别:

import {MyComponent} from '../components/xyz.js';

vs

import MyComponent from '../components/xyz.js';

第二个工作,而第一个造成错误。或者正好相反。


在我的例子中,这是由错误的注释符号引起的。这是错误的:

<Tag>
    /*{ oldComponent }*/
    { newComponent }
</Tag>

这是正确的:

<Tag>
    {/*{ oldComponent }*/}
    { newComponent }
</Tag>

注意花括号


在我的例子中,导入是由于库而隐式发生的。

我设法通过改变来解决它

导出类Foo

to

导出默认类Foo。


作为一个快速的补充。我也遇到了同样的问题,当Webpack编译我的测试时,应用程序运行良好。当我将我的组件导入到测试文件中时,我在其中一个导入中使用了错误的大小写,这导致了同样的错误。

import myComponent from '../../src/components/myComponent'

应该是

import myComponent from '../../src/components/MyComponent'

注意,导入名称myComponent依赖于myComponent文件中导出的名称。


如果你得到这个错误,这可能是因为你导入链接使用

import {Link} from 'react-router'

相反,使用它可能会更好

import { Link } from 'react-router-dom'
                      ^--------------^

我相信这是react路由器版本4的一个要求


另一个可能的解决方案,对我来说很管用:

目前,react-router-redux处于测试阶段,npm返回4。X,但不是5.x。但是@types/react-router-redux返回5.x。这里使用了未定义的变量。

强制NPM/Yarn使用5。X帮我解出来了。


在我的例子中,导出的子模块之一没有返回正确的react组件。

const Component = <div> Content </div>;

而不是

const Component = () => <div>Content</div>;

显示的错误是针对父进程的,因此无法找出。


我通过import App from './ App /'获得;期望它导入。/app/index.js,但它却导入了。/app.json。


当我在同一目录中有一个.jsx和.scss文件且根名称相同时,我遇到了这个错误。

举个例子,如果你有Component。jsx和Component。SCSS在同一个文件夹中,你试着这样做:

import Component from ./Component

Webpack显然混淆了,至少在我的情况下,当我真正想要.jsx文件时,它试图导入scss文件。

我可以通过重命名.scss文件并避免歧义来修复它。我还可以显式地导入Component.jsx


我也遇到了同样的问题,并意识到我在JSX标记中提供了一个未定义的React组件。问题是要渲染的react组件是动态计算的,它最终没有定义!

错误说明:

不变性违反:元素类型无效:期望为字符串(对于内置组件)或类/函数(对于复合组件),但得到:undefined。您可能忘记从定义组件的文件中导出组件。检查C.的渲染方法,

产生此错误的示例:

var componentA = require('./components/A'); var componentB = require('./components/B'); const templates = { a_type: componentA, b_type: componentB } class C extends React.Component { constructor(props) { super(props); } // ... render() { //Let´s say that depending on the uiType coming in a data field you end up rendering a component A or B (as part of C) const ComponentTemplate = templates[this.props.data.uiType]; return <ComponentTemplate></ComponentTemplate> } // ... }

问题是提供了一个无效的“uiType”,因此产生了未定义的结果:

模板['无效字符串']


对我来说,我的样式组件是在我的功能组件定义之后定义的。它只发生在舞台上,对我来说不是局部的。一旦我把我的样式化组件移到组件定义的上方,错误就消失了。


React Native最新版本0.50及以上也有类似问题。

对我来说,这是一种区别:

import App from './app'

and

import App from './app/index.js'

(后者解决了这个问题)。我花了好几个小时才发现这个奇怪的,很难注意到的细微差别:(


在我的例子中,我只是在我的一个子模块的import- declaration中缺少了一个分号。

通过改变这个修正:

import Splash from './Splash'

:

import Splash from './Splash';

除了进口/出口问题提到。我发现使用React.cloneElement()向子元素添加道具,然后渲染它给了我同样的错误。

我不得不改变:

render() {
  const ChildWithProps = React.cloneElement(
    this.props.children,
    { className: `${PREFIX}-anchor` }
  );

  return (
    <div>
      <ChildWithProps />
      ...
    </div>
  );
}

to:

render() {
  ...
  return (
    <div>
      <ChildWithProps.type {...ChildWithProps.props} />
    </div>
  );
}

有关更多信息,请参阅React.cloneElement()文档。


我也犯了同样的错误: 错误修复!!!!

我使用'react-router-redux' v4,但她不好.. 在npm安装react-router-redux@next 我在"react-router-redux"上:"^5.0.0-alpha.9",

这就是工作


不要对一个问题的答案列表感到惊讶。造成这个问题的原因有很多;

对我来说,警告是

Warning .js:33警告:反应。createElement: type无效——期望一个字符串(对于内置组件)或一个类/函数(对于复合组件),但得到:undefined。您可能忘记从定义组件的文件中导出组件。在index.js:13处检查代码。

后面是错误

元素类型无效:期望为字符串(对于内置组件)或类/函数(对于复合组件),但得到:undefined。您可能忘记从定义组件的文件中导出组件。

我无法理解这个错误,因为它没有提到任何方法或文件名。我只是在看了上面提到的这个警告后才解决了这个问题。

我在index.js中有如下一行。

<ConnectedRouter history={history}>

当我用关键字“ConnectedRouter”谷歌上面的错误时,我在GitHub页面上找到了解决方案。

这个错误是因为,当我们安装react-router-redux包时,默认情况下我们安装这个包。 https://github.com/reactjs/react-router-redux但不是实际的库。

要解决这个错误,请使用@指定npm作用域来安装正确的包

npm install react-router-redux@next

不需要删除错误安装的软件包。它将被自动覆盖。

谢谢你!

PS:即使是警告也能帮助你。不要只看错误而忽略警告。


在我的情况下,我使用默认导出,但不导出函数或React。组件,但只是一个JSX元素,即。

错误:

export default (<div>Hello World!</div>)

工作原理:

export default () => (<div>Hello World!</div>)

这意味着您导入的某些组件声明错误或不存在

我也有类似的问题,真的

import { Image } from './Shared'

但是当我查看共享文件时,我没有'Image'组件,而是'ItemImage'组件

import { ItemImage } from './Shared';

当你从其他项目复制代码时会发生这种情况;)


@Balasubramani M救了我。想再加一个来帮助人们。当你把太多的东西粘在一起,对版本漫不经心时,这就是问题所在。我更新了material-ui的一个版本,需要更改

import Card, {CardContent, CardMedia, CardActions } from "@material-ui/core/Card"; 

:

import Card from '@material-ui/core/Card';
import CardActions from '@material-ui/core/CardActions';
import CardContent from '@material-ui/core/CardContent';
import CardMedia from '@material-ui/core/CardMedia';

我有同样的问题,问题是一些js文件不包括在该特定页面的捆绑。尝试包括这些文件,问题可能会得到解决。 我是这样做的:

.Include("~/js/" + jsFolder + "/yourjsfile")

它帮我解决了这个问题。

这是当我使用React在Dot NEt MVC


我发现了这个错误的另一个原因。它与CSS-in-JS向React组件中返回函数的顶层JSX返回空值有关。

例如:

const Css = styled.div`
<whatever css>
`;
export function exampleFunction(args1) {
  ...
  return null;
}

export default class ExampleComponent extends Component {
...
render() {
const CssInJs = exampleFunction(args1);
  ...
  return (
    <CssInJs>
      <OtherCssInJs />
      ...
    </CssInJs>
  );
}

我会得到这样的警告:

警告:反应。createElement: type无效——期望一个字符串(对于内置组件)或一个类/函数(对于复合组件),但得到:null。

接着是这个错误:

未捕获错误:元素类型无效:期望为字符串(对于内置组件)或类/函数(对于复合组件),但得到:null。

我发现这是因为我试图渲染的CSS-in- js组件没有CSS。我通过确保有CSS被返回而不是一个空值来修复它。

例如:

const Css = styled.div`
<whatever css>
`;
export function exampleFunction(args1) {
  ...
  return Css;
}

export default class ExampleComponent extends Component {
...
render() {
const CssInJs = exampleFunction(args1);
  ...
  return (
    <CssInJs>
      <OtherCssInJs />
      ...
    </CssInJs>
  );
}

我得到了几乎相同的错误:

Uncaught (in promise)错误:元素类型无效:期望一个字符串(对于内置组件)或类/函数(对于复合组件),但得到:object。

我试图从我的团队开发的另一个节点库导入一个纯功能组件。为了解决这个问题,我必须将其更改为绝对导入(引用node_modules内部组件的路径)

import FooBarList from team-ui

to

import FooBarList from team-ui/lib/components/foo-bar-list/FooBarList


在我的例子中,它最终是像这样导入的外部组件:

import React, {Component}

然后声明如下:

导出默认类MyOuterComponent

其中一个内部组件导入了React bare:

import React from

用虚线表示声明:

导出默认类MyInnerComponent


在我的例子中,我花了很多时间来搜索和检查可能的方法,但只有通过这种方式来修复:在导入自定义组件时删除“{”,“}”:

import OrderDetail from './orderDetail';

我的错误做法是:

import { OrderDetail } from './orderDetail';

因为在OrderDetail .js文件中,我将OrderDetail导出为默认类:

class OrderDetail extends Component {
  render() {
    return (
      <View>
        <Text>Here is an sample of Order Detail view</Text>
      </View>
    );
  }
}

export default OrderDetail;

在升级所有库到最新版本时,我得到了这个错误

在旧版本中,以下是导入

import { TabViewAnimated, TabViewPagerPan } from 'react-native-tab-view';

但在新版本中,它们被以下内容所取代

import { TabView, PagerPan } from "react-native-tab-view";

因此,请检查正确的所有导入可用的使用控制单击


假设你的错误是:

未捕获错误:不变量违反:元素类型无效:期望为字符串(对于内置组件)或类/函数,但got: object

你有两个选择:

您的导出文件可以有字默认,如

export default class someNameHere

那么您的导入将需要避免在它周围使用{}。就像在

import somethingHere from someWhereHere

避免使用默认单词。然后你的导出是这样的

export class someNameHere

然后导入必须使用{}。就像

import {somethingHere} from someWhereHere

在我的例子中,它是元标签。

我在用

const MetaTags = require('react-meta-tags');

我猜MetaTags是一个默认的导出,所以改变为这个解决了我,花了几个小时来弄清楚是哪一个导致它。

const { MetaTags } = require('react-meta-tags');

我在React上遇到了点问题。Fragment,因为我的react的版本是< 16.2,所以我去掉了它。


在文件底部导出可以解决这个问题。

const IndicatorCloak = (props) => { ... }
export default IndicatorCloak;

我在反应路由中得到了这个错误,问题是我正在使用

<Route path="/" component={<Home/>} exact /> .

但这是错误的路线需要组件作为类/函数,所以我把它改成了

<Route path="/" component={Home} exact />

这招奏效了。(只需避免在组件周围使用大括号)


问题还可能是用于默认导出的别名。

改变

import { Button as ButtonTest } from "../theme/components/Button";

to

import { default as ButtonTest } from "../theme/components/Button";

帮我解决了这个问题。


我也遇到了同样的问题,因为我确实导入了不正确的库,所以我检查了库中的文档,路由用新的versión更改了,解决方案是这样的:

import {Ionicons} from '@expo/vector-icons';

我写错了:

import {Ionicons} from 'expo';

我错误地试图从react-native而不是native-base导入容器和内容。

错误,因为这一行:

import { ActivityIndicator, RefreshControl,  StyleSheet, View, Keyboard, Container, Content } from 'react-native';

下面是代码修复:

import { ActivityIndicator, RefreshControl,  StyleSheet, View, Keyboard } from 'react-native';
import { Container, Content} from 'native-base';

在我的情况下,我写了const Tab = createBottomTabNavigator而不是const Tab = createBottomTabNavigator()


我也有这个问题。我的导入看起来很好,我可以复制我的副本的内容,并将其粘贴到它正在使用的地方,这是有效的。但是对组件的引用出了问题。

对我来说,我只需要关闭expo并重新启动它。


我也得到了这个错误。错误是由试图像这样导出一个组件引起的…

export default Component();

而不是这样…

export default Component;

我的理解是,通过在组件的末尾添加“()”,我实际上是在调用函数,而不仅仅是引用它。

我在上面的答案中没有看到这一点,但可能错过了。我希望它能帮助一些人,节省一些时间。我花了很长时间才找到这个错误的根源!


我想为这个问题补充一个案例。我通过交换导入顺序来解决这个问题,例如在之前的混合导入中:

import { Label } from 'components/forms/label';
import Loader from 'components/loader/loader';
...
import Select from 'components/select/select'; // <----- the error happen

变更后:

import Select from 'components/select/select'; // <----- Fixed
import { Label } from 'components/forms/label';
import Loader from 'components/loader/loader';
...

在嵌套组件时,您是否厌倦了简单的导入/导出回答?

好吧,当我试图把道具从父母传递给孩子时,孩子应该渲染兄弟姐妹组件。

比方说,你有一个BaseDialog(父)组件,你想在其中有另一个SettingsDialog(子)组件,你想在其中呈现它的独立组件。

BaseDialog.tsx

import BaseButton from "./../BaseButton";
...
<SettingsDialog
  BaseButton={<BaseButton title="Connect Wallet" />}
/>

你试图在settings。dialog。tsx的某个地方进行渲染

const SettingsDialog = (props: {
  BaseButton: any;
}) => {
  const { BaseButton } = props;

  return(
    <div>
      {BaseButton}
    </div>
  );
}

(是的,这是一种方便的方法来传递组件的父->子,特别是当它们增长时,但在这里它会中断),但它会导致Uncaught Error: Invariant Violation:元素类型是无效的:期望一个字符串(对于内置组件)或类/函数,但got: object错误。

你能做的是,修复它,并仍然使用BaseButton,只是单独导入它。

Settings.Dialog.tsx

import BaseButton from "./../BaseButton";

const SettingsDialog = () => {
  return(
    <div>
      <BaseButton title="Connect Wallet" />
    </div>
  );
}

在parent中

BaseDialog.tsx

<SettingsDialog />

您试图实现的是相同的,并将修复这个不直观的错误。

在我的例子中,我假设BaseDialog有一个名称标题的必需道具。


错误呢?这肯定是一个导入或导出的问题,你引用了一个组件或容器,要么你没有从它的定义脚本导出,要么你在导入它时使用了错误的格式。

解决方案吗?

遍历所有的组件/容器定义,并确保在脚本的末尾导出了它们,例如“export default 'yourcomponentname';”或者在组件定义的开头,例如“export default 'yourcomponentname'; Export const 'yourcomponentname'=() =>{ …… } 在导入语句中,确保没有根据相应的导出语句将命名导入和默认导入混为一谈


当我更改此代码时,错误已被修复

AppRegistry.registerComponent(appName, App );

到此代码:

AppRegistry.registerComponent(appName, () => App);

在类似的情况下,我有同样严重的错误,我专注于代码,但以上似乎没有改善情况。我正在从Javascript转换到Typescript,但由于一些奇怪的原因,我同时拥有两个文件。删除JS版本解决了这个问题,这可能会节省一些人的时间。


就我而言,

//details.js 
import React from 'react'

const Details = (props) =>{
return <h1>Details</h1>
}

export default Details;


//main.js
import React from "react";
import { withRouter } from "react-router";
import {Route,BrowserRouter as Router,Redirect,Switch,Link} from "react-router-dom";
import Details from "./myAccount/details";

const Main = (props) => {
 return (
   <>
        <Switch>
          <Route path="/my-account/details" component={<Details />} />
        </Switch>
   </>

 );
};

export default withRouter(Main);

===========================

Replaced with below one, error got fixed
component={<Details />}  with  component={Details} 

对我来说,它是app config json的名称。在index.js中,导入是这样的:

import { AppRegistry } from 'react-native'
import App from './app'
import { name as appName } from './app.json'

AppRegistry.registerComponent(appName, () => App)

React Native不区分'。./app '和'./app.json'。不知道为什么。因此,我已经将app.json的名称更改为app.config.json,这已经解决了问题:

import { AppRegistry } from 'react-native'
import App from './app'
import { name as appName } from './app.config.json'

AppRegistry.registerComponent(appName, () => App)

确保只返回一个PARENT - CHILD

这是可行的

<div>
    <p> Something here </p>
</div>

这行不通

<div>
    <p> Something here </p>
</div>
<div>
    <p> Something else here </p>
</div>

我不相信我的情况和补救措施在这里讨论,所以我补充。

我有一个函数,它返回一个名为notification的对象

import IconProgress from '../assets/svg/IconProgress';

  const getNotificationFromAttachment = (attachment) => {
    const notification = {
    Icon: IconProcessing,
    iconProps: {},
  };
  
  ...
  notification.Icon = {IconProgress};
  
  return notification
}

React期望一个字符串或类/函数作为变量通知的值。图标

所以你所需要做的就是将{IconProgress}改为IconProgress

见下图:


问题可能在于使用SVG作为组件。

import { ReactComponent as HeaderLogo } from "../../assets/logoHeader.svg";
    
    const Header = () => {
        return (
            <div>
                <HeaderLogo />
            </div>
        );
    };

你可以这样显示一张图片:

import HeaderLogo from "../../assets/logoHeader.svg";

const Header = () => {
    return (
        <div>
            <img src={HeaderLogo} alt="React Logo" />
        </div>
    );
};

对我来说,这是因为我的组件由于某种原因没有使用*符号导出,所以我必须显式地命名导出

// index.ts
export * from "./Button"

to

// index.ts
export { Button } from "./Button"