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文件中引入两个按钮

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

在这里插入图片描述

相关推荐
喝拿铁写前端12 小时前
一套面向 Web、H5、小程序与 Flutter 的多端一致性技术方案
前端·架构
yaaakaaang12 小时前
(一)前端,如此简单!---下载Nginx
前端·nginx
牛奶12 小时前
为什么全国人民都能秒开同一个视频?
前端·http·cdn
KongHen0212 小时前
uniapp-x实现自定义tabbar
前端·javascript·uni-app·unix
汪子熙12 小时前
TS2320 错误的本质、触发场景与在 Angular / RxJS 项目中的系统化应对
前端·javascript·angular.js
我命由我1234513 小时前
React - BrowserRouter 与 HashRouter、push 模式与 replace 模式、编程式导航、withRouter
开发语言·前端·javascript·react.js·前端框架·html·ecmascript
Younglina13 小时前
用AI全自动生成连环画?我试了,效果惊艳!
前端·ai编程·claude
Devin_chen13 小时前
ES6 Class 渐进式详解
前端·javascript
小番茄夫斯基13 小时前
前端开发的过程中,需要mock 数据,但是走的原来的接口,要怎么做
前端·javascript
peachSoda713 小时前
前端想转AI全栈-初步练习记录
前端·人工智能