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

前端 未结 30 1112
孤城傲影
孤城傲影 2020-11-22 06:53

I am getting this error:

Uncaught Error: Invariant Violation: Element type is invalid: expected a string (for built-in components) or a class/funct

相关标签:
30条回答
  • 2020-11-22 07:31

    In my case, one of the exported child module was not returning a proper react component.

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

    instead of

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

    The error shown was for the parent, hence couldn't figure out.

    0 讨论(0)
  • 2020-11-22 07:32

    I've discovered another reason for this error. It has to do with the CSS-in-JS returning a null value to the top-level JSX of the return function in a React component.

    For example:

    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>
      );
    }
    

    I would get this warning:

    Warning: React.createElement: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: null.

    Followed by this error:

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

    I discovered it was because there was no CSS with the CSS-in-JS component that I was trying to render. I fixed it by making sure there was CSS being returned and not a null value.

    For example:

    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>
      );
    }
    
    0 讨论(0)
  • 2020-11-22 07:33

    I got this error in react routing, problem was that I was using

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

    but it was wrong route requires component as a class/function so I changed it to

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

    and it worked. (Just avoid the braces around the component)

    0 讨论(0)
  • 2020-11-22 07:33

    For me it was that my styled-components were defined after my functional component definition. It was only happening in staging and not locally for me. Once I moved my styled-components above my component definition the error went away.

    0 讨论(0)
  • 2020-11-22 07:34

    I have the same error : ERROR FIX !!!!

    I use 'react-router-redux' v4 but she's bad.. After npm install react-router-redux@next I'm on "react-router-redux": "^5.0.0-alpha.9",

    AND IT'S WORK

    0 讨论(0)
  • 2020-11-22 07:34

    I was having the same issue and realized that I was providing an Undefined React component in the JSX markup. The thing is that the react component to render was dynamically calculated and it ended up being undefined!

    The error stated:

    Invariant Violation: Element type is invalid: expected a string (for built-in components) or a class/function (for composite components) but got: undefined. You likely forgot to export your component from the file it's defined in. Check the render method of C.,

    The example producing this error:

    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>
      }
      
      // ...
    }

    The problem was that an invalid "uiType" was provided and therefore this was producing undefined as result:

    templates['InvalidString']

    0 讨论(0)
提交回复
热议问题