React中的BUG记录——Error: Element type is invalid: expected a string (for built-in components) or a class

问题描述

语法各个方面没有问题,报以下错误:
Error: Element type is invalid: expected a string (for built-in components) or a class/function (for composite components) but got: object.
Check the render method of App.

代码

index.js

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App'

ReactDOM.render(
    <App/>,
  document.getElementById('root')
);

app.js


import './App.css';
import Inputdemo from './components/Inputdemo';
import JsonDatause from './components/JsonDatause';
import Datause from './components/Datause'

function App() {
  return (
    <div>
      <JsonDatause />
      <hr/>
      <Inputdemo />
      <hr/>
      <Datause />
    </div>
  );
}
export default App

通过注释溯源方法得出Datause组件出现问题

Datause.js

import React, { Component } from 'react'
import Datamytest from './Datause.json';
// 这个文件对输入的json文件内容进行统一加入默认属性,使用展现出来

export default class Datause extends Component {
    constructor(props) {
        super(props);
        this.state = {
            data: {
                total: 0,
                records: [{}, {}],
            }
        };
    }
    componentDidMount() {
        this.loadData();
    }
    loadData = () => {
        const datatest = Datamytest;
        datatest.forEach((item, index) => {
            item.age = index+1;
            item.title = "index";
        })
        // const a = Object.assign({}, this.state.data, { total: datatest.length, records: datatest });
        this.setState({
            data: { total: datatest.length, records: datatest },
        }, () => {
            console.log(this.state.data);
        });
    };

    render() {
        const { data } = this.state;
        console.log(data.records);
        return (
            <div>
                {data.records.length && data.records.map((item,index) => 
                    <div key={index} title={item.id}>
                        <span > &nbsp;&nbsp;&nbsp;&nbsp;   {item.id}        &nbsp;&nbsp;&nbsp;&nbsp;  </span>
                        <span > &nbsp;&nbsp;&nbsp;&nbsp;   {item.title}     &nbsp;&nbsp;&nbsp;&nbsp; </span>
                        <span > &nbsp;&nbsp;&nbsp;&nbsp;   {item.age}       &nbsp;&nbsp;&nbsp;&nbsp; </span>
                        <span > &nbsp;&nbsp;&nbsp;&nbsp;   {item.isvName}   &nbsp;&nbsp;&nbsp;&nbsp;  </span>
                    </div>
                )}
            </div>
        )
    }
}

以上三个文件都没有语法以及各方面的错误,yarn start运行的时候也是成功,但是网页出现了如图示的错误。
在这里插入图片描述

在这里插入图片描述

问题原因:

组长说可能是缓存问题。

解决方法:

重命名文件

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值