react项目实战教程(react项目实战)

文章目录项目实战前的准备工作项目实战一.搭建项目的基本页面及外层路由1-1配置基本页面1-2配置路由1-3需要最外层去渲染路由视图1-4需要配置内层App路由1-5路由的懒加载二.利用Antd实现组件2-1使用Antd的Layout进行布局2-2可以设计个Logo2-3实现左侧的菜单展示2-4实现左侧的小图标2-5实现点击菜单切换总结需要下载的组件项目实战前的准备工作React基础…

大家好,又见面了,我是你们的朋友全栈君。

项目实战前的准备工作

React基础
React组件
React-Router——Reac路由的学习
React高阶组件及CRA的定制
React中使用Antd组件

React项目实战(一)

React项目实战(二)

搭建项目的基本页面及外层路由

1-1配置基本页面

在项目根目录src文件下创建views文件夹
在这里插入图片描述
然后在views文件夹里创建所需要页面,
在相应文件夹下创建index.js文件,这样引入所需页面的时候直接写./login即可,不需要再写./login/index.js

  • article(index.js / Edit.js) 文章列表 文章编辑
  • dashboard(index.js) 仪表盘
  • login(index.js) 登录
  • settings(index.js) 设置
  • notfound(index.js) 404

在这里插入图片描述

  • 最后再创建views/index.js,并在文件里导出页面
import Article from "./article"      //文章列表
import ArticleEdit from "./article/Edit"//文章编辑
import Dashboard from "./dashboard"//仪表盘
import Login from "./login"//登录
import Notfound from "./notfound"//404
import Settings from "./settings"//设置

export { 
   
    Article,
    ArticleEdit,
    Dashboard,
    Login,
    Notfound,
    Settings
}

1-2配置路由

  • 安装路由:yarn add react-router-dom或者npm i react-router-dom
  • src文件下新建routes文件夹,在其下新建index.js文件并配置路由
    在这里插入图片描述
    routes/index.js
import  { 
   
    Article,
    ArticleEdit,
    Dashboard,
    Login,
    Notfound,
    Settings
} from "../views"   //引入页面


// /login 页面 /404 页面 
export const mainRoute = [
    { 
   
        pathname:"/login",
        component:Login
    },
    { 
   
        pathname:"/404",
        component:Notfound
    }
]


// /admin/XXX dashboard article articleEdit settings 管理页面
export const admainRoute = [
    { 
   
        pathname:"/admin/dashboard",
        component:Dashboard
    },
    { 
   
        pathname:"/admin/article",
        component:Article,
        exact:true  //配置App内置路由需要exact属性,详情见下文
    },
    { 
   
        pathname:"/admin/article/edit/:id",
        component:ArticleEdit
    },
    { 
   
        pathname:"/admin/settings",
        component:Settings
    },
]

1-3需要最外层去渲染路由视图

  • src/index.js文件里渲染路由视图
    在这里插入图片描述
import React from 'react';
import ReactDOM from 'react-dom';
import App from './App';
import { 
   HashRouter as Router,Route,Redirect,Switch} from "react-router-dom"
import { 
   mainRoute} from "./routes"
ReactDOM.render(
  <Router>
    <Switch>
      <Route path="/admin" component={ 
   App}/> //admin主页面的路由 进入到App组件
      { 
   
        mainRoute.map(route=>{ 
   
          return <Route path={ 
   route.pathname} component={ 
   route.component}/>
        })
      }  //遍历login 404 的路由
      <Redirect to="/admin" from="/" exact/>  //重定向 首页为admin
      <Redirect to="/404" />		//如果路径与之前都不匹配,则返回404页面
    </Switch>
  </Router>
  ,
  document.getElementById('root')
);

1-4需要配置内层App路由

  • src/App.js文件里渲染路由视图
    在这里插入图片描述
import React, { 
    Component } from 'react'
import { 
   admainRoute} from "./routes"
import { 
   Route,Redirect,Switch} from "react-router-dom"
export default class App extends Component { 
   
  render() { 
   
    return (
      <Switch>
        { 
   
          admainRoute.map(route=>{ 
   
            return <Route path={ 
   route.pathname} component={ 
   route.component} exact={ 
   route.exact}/>
          })
        }   //admin页面里的路由 dashboard article articleEdit settings
        <Redirect to={ 
   admainRoute[0].pathname} from="/admin" exact/>  //重定向到 admin页面
        <Redirect to="/404" />
      </Switch> 
    )
  }
}
  • 后续发现了问题 /admin/article显示Article中的内容 但是/admin/article/edit/2的时候不显示ArticleEdit中的内容
    解决方法,直接在routes/index.js里面添加一个标志exact然后遍历路由的时候判断是否要添加exact属性
    { 
   
        pathname:"/admin/article",
        component:Article,
        exact:true
    },

    { 
   
              admainRoute.map(route=>{ 
   
                return <Route    exact={ 
   route.exact}/>
              })
    }

1-5 路由的懒加载

  • 下载react-loadable
    通过yarn add react-loadable安装
    在npm官网中搜索查阅使用方法
    在这里插入图片描述

  • 并新建src/component/loading/index.js文件,当懒加载未完成时,会显示该页面的内容
    在这里插入图片描述

  • 更改src/views/index.js文件

import Loadable from 'react-loadable';
import Loading from '../components/loading';
//需要将对外的普通组件需要进行懒加载
const Article = Loadable({ 
   
    loader: () => import('./article'),
    loading: Loading,
});
const Dashboard = Loadable({ 
   
    loader: () => import('./dashboard'),
    loading: Loading,
});
const ArticleEdit = Loadable({ 
   
    loader: () => import('./article/Edit'),
    loading: Loading,
});
const Login = Loadable({ 
   
    loader: () => import('./login'),
    loading: Loading,
});
const Notfound = Loadable({ 
   
    loader: () => import('./notfound'),
    loading: Loading,
});
const Settings = Loadable({ 
   
    loader: () => import('./settings'),
    loading: Loading,
});


export  { 
   
    Article,
    ArticleEdit,
    Dashboard,
    Login,
    Notfound,
    Settings
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128605.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • navicat15激活码最新【最新永久激活】

    (navicat15激活码最新)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html70YZDJVTFP-eyJsaWNlbnNlSW…

    2022年3月26日
    55
  • 网站的推广方案有哪些_推广方案范例

    网站的推广方案有哪些_推广方案范例做网站推广也已经有了5、6年了,看了很多网站推广的方法方案,网上流传的100种主要推广方法方案都是一样的,2017年又不什么新的100种主要方法方案吗?在这里厦门网站推广公司领众品牌就2017网站推广

    2022年8月3日
    6
  • 常用的算法和数据结构 面试_数据结构与算法面试题80道

    常用的算法和数据结构 面试_数据结构与算法面试题80道(1)红黑树的了解(平衡树,二叉搜索树),使用场景把数据结构上几种树集中的讨论一下:1.AVLtree定义:最先发明的自平衡二叉查找树。在AVL树中任何节点的两个子树的高度最大差别为一,所以它也被称为高度平衡树。查找、插入和删除在平均和最坏情况下都是O(logn)。增加和删除可能需要通过一次或多次树旋转来重新平衡这个树。节点的平衡因子是它的左子树的高度减去它的右子树的高度(有时相反)。…

    2022年8月18日
    6
  • gitbook如何_github入门与实践

    gitbook如何_github入门与实践  本文从“是什么”、“为什么”、“怎么办”、“好不好”四个维度来介绍GitBook,带你从黑暗之中走出来,get这种美妙的写作方式。是什么?  在我认识GitBook之前,我已经在使用Git了,毋容置疑,Git是目前世界上最先进的分布式版本控制系统。  我认为Git不仅是程序员管理代码的工具,它的分布式协作方式同样适用于很多场合,其中一个就是写作(这会是一个…

    2022年10月4日
    2
  • nodejs爬虫与python爬虫_不再羡慕python,nodejs爬虫撸起袖子就是干,爬取宅男女神网大姐姐的高清图片!…[通俗易懂]

    nodejs爬虫与python爬虫_不再羡慕python,nodejs爬虫撸起袖子就是干,爬取宅男女神网大姐姐的高清图片!…[通俗易懂]年前无心工作,上班刷知乎发现一篇分享python爬虫的文章。感觉他爬取的网站里的妹子都好好看哦,超喜欢这里的,里面个个都是美女。无奈python虽然入门过但太久没用早已荒废,最近在用nodejs重构后台接口,遂尝试用nodejs实现个爬虫。先上几张图:爬几个相册示范一下都是高清无码大图哦好了,开始准备工作吧,少年!喂!我说的是准备工作环境!你,你,还有你,你们把手上的纸巾放下!准备工作:系统环境:…

    2022年6月5日
    26
  • vue前端ui框架_详细讲解帕米尔的春天

    vue前端ui框架_详细讲解帕米尔的春天本文章描述的是Swagger3.0的内容,与Swagger2.0内容有较大差别。接口描述在3.0中通过Swagger规范(一个JSON文件)来描述,Swagger2.0是通过在接口中提供一系列注解来描述的。 1.集成Swagger    Swagger提供了一组静态页面,可以在SpringBoot应用中集成这些静态页面,直接访问静态页面,并打开指定的Swagger规范,就可以…

    2025年6月24日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号