react脚手架初始化项目及ts的应用(react+ts)

1. 安装react脚手架

npm install -g create-react-app
或是
yarn add -g create-react-app

2. 初始化项目

快速构建出项目名为my-app的react+ts项目

create-react-app my-app --template typescript

拓展:

npx
npx create-react-app my-app

(npx附带npm 5.2+及更高版本,请参阅旧版本npm的说明)

npm
npm init react-app my-app

支持在 npm 6+版本以上

Yarn
yarn create react-app my-app

Yarn 0.25+ 以上支持

3. 配置路径别名

  • 在引入文件时如果都是.../ .../.../这种相对路径方式引用可读性很差

  • 安装依赖

    npm install react-app-rewired customize-cra --save-dev

在项目根路径下创建config-overrides.js文件,添加如下配置

const { override, addWebpackAlias } = require('customize-cra')
const path = require('path')
module.exports = override(
  addWebpackAlias({
    // 指定@符指向src目录
    '@': path.resolve(__dirname, 'src'),
  })
)

4. 路由配置

1.src下index引入

import { Router, Route } from 'react-router-dom';
import history from './history';

2.自建history路由中间件history.js

import {createBrowserHistory} from 'history';
export default createBrowserHistory();

3.src下index加路由

  • 每一个Link只能在Router中

  • 自己配置history这样在接下来的项目中就可以直接使用
    history.push('/cart')

    ReactDOM.render(
    <React.StrictMode>
    <Router history={history}>
    <Route path="/" component={Index}/>
    <Route path="/myPersonal" component={MyPersonal}/>
    <Route path="/otherPersonal" component={OtherPersonal}/>
    </Router>,
    </React.StrictMode>,
    document.getElementById('root')
    );

5.引入Ant-Design组件库

1.安装依赖

npm install antd --save

2.在App.tsx文件中引入两个按钮

查看效果,按钮正常显示说明就是成功了;

在这里插入图片描述

相关推荐
耶啵奶膘22 分钟前
uniapp-是否删除
linux·前端·uni-app
王哈哈^_^2 小时前
【数据集】【YOLO】【目标检测】交通事故识别数据集 8939 张,YOLO道路事故目标检测实战训练教程!
前端·人工智能·深度学习·yolo·目标检测·计算机视觉·pyqt
cs_dn_Jie2 小时前
钉钉 H5 微应用 手机端调试
前端·javascript·vue.js·vue·钉钉
开心工作室_kaic3 小时前
ssm068海鲜自助餐厅系统+vue(论文+源码)_kaic
前端·javascript·vue.js
有梦想的刺儿3 小时前
webWorker基本用法
前端·javascript·vue.js
cy玩具4 小时前
点击评论详情,跳到评论页面,携带对象参数写法:
前端
清灵xmf4 小时前
TypeScript 类型进阶指南
javascript·typescript·泛型·t·infer
qq_390161774 小时前
防抖函数--应用场景及示例
前端·javascript
John.liu_Test5 小时前
js下载excel示例demo
前端·javascript·excel
Yaml45 小时前
智能化健身房管理:Spring Boot与Vue的创新解决方案
前端·spring boot·后端·mysql·vue·健身房管理