reactjs React组件内容未呈现或未找到

qyzbxkaa  于 2023-02-04  发布在  React
关注(0)|答案(2)|浏览(158)

我第一次用React构建一个前端,刚刚添加了路由,从那以后,页面就不能正确呈现了,我不知道错误在哪里。
View when I go to the homepage path
组件内容似乎未加载
这是我的App.js和路线

import './App.css';
import React, { useState } from 'react';
import { Route, Routes, Switch } from "react-router-dom";
import homePage from './Pages/home';
import loginPage from './Pages/login';
import galleryPage from './Pages/gallery';

function App() {
  return (
    <>
      <Routes>
        <Route path='/' exact element={<homePage />}/>
        <Route path='/login' element={<loginPage />}/>
        <Route path='/gallery' element={<galleryPage />}/>
        <Route path='/dev' element={<test />}></Route>
      </Routes>
    </>
  );
}

export default App;

这里是我的index.js

import React from 'react';
import ReactDOM from 'react-dom/client';
import './index.css';
import App from './App';
import reportWebVitals from './reportWebVitals';
import { BrowserRouter } from 'react-router-dom'

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(
  <React.StrictMode>
    <BrowserRouter>
      <App />
    </BrowserRouter>
  </React.StrictMode>
);

reportWebVitals();

这里是我的家

import Navbar from "../Components/Navigation/Navbar";
import Calendartsc from "../Components/Calendar/calendar";
import Events from "../Components/Events/Events";
import React from "react";
import '../index.css';
import './home.css'

let inhalt = "Temporary test content"

function homePage() {
  return (
    <>
      <div className="App">
        <title>Vereinswebsite</title>
        <Navbar />
        <div className='card'>
          <h2>Wilkommen</h2>
          <div className="flex-container">
            {inhalt}
          </div>
          <div className="flex-container">
            <div className='flex-child magenta'>
              <div className='card'>
                <Calendartsc />
              </div>
            </div>
            <div className='flex-child green'>
              <div className='card'>
                <Events />
              </div>
            </div>
          </div>
        </div>
      </div>
    </>
  );
}

export default homePage;

我的软件包. json

{
 "name": "test",
 "version": "0.1.0",
  "private": true,
  "dependencies": {
    "@testing-library/jest-dom": "^5.16.5",
    "@testing-library/react": "^13.4.0",
    "@testing-library/user-event": "^13.5.0",
    "@types/react": "^18.0.26",
    "react": "^18.2.0",
    "react-bootstrap": "^2.7.0",
    "react-calendar": "^4.0.0",
    "react-dom": "^18.2.0",
    "react-router-dom": "^6.6.2",
    "react-scripts": "^2.1.3",
    "web-vitals": "^2.1.4"
 },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject"
  },
  "browserslist": {
    "production": [
      ">0.2%",
      "not dead",
      "not op_mini all"
     ],
    "development": [
      "last 1 chrome version",
      "last 1 firefox version",
      "last 1 safari version"
    ]
  }
}

我没有正确调用组件吗?
我想让React组件呈现在正确的路径上,当前只呈现HTML标记,而不呈现作为返回值存储在函数中的内容。

zbdgwd5y

zbdgwd5y1#

问题是您使用小写字母呈现组件。
React JSX会将任何小写的tag视为常规的HTML tag。如果标记不存在,则会将其呈现为DIV
而不是呈现它,因为你张贴:

<Route path='/' exact element={<homePage />}/>

您需要将其渲染为:

<Route path='/' exact element={<HomePage />}/>

而不是导入它,因为你张贴:

import homePage from './Pages/home';

您需要按如下方式导入组件:

import HomePage from './Pages/home';
pu82cl6c

pu82cl6c2#

在React中,如果组件名称以小写字母开头,则会尝试加载默认HTML组件,如divspan等。由于不存在homePage等HTML组件,因此不会加载任何内容。
因此,将您的组件重命名为HomePageLoginPage ......等,应该可以正常工作。

相关问题