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

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

在这里插入图片描述

相关推荐
共享家95276 小时前
搭建 AI 聊天机器人:”我的人生我做主“
前端·javascript·css·python·pycharm·html·状态模式
Halo_tjn7 小时前
基于封装的专项 知识点
java·前端·python·算法
摘星编程7 小时前
OpenHarmony环境下React Native:自定义useTruncate文本截断
javascript·react native·react.js
m0_748229999 小时前
Vue2 vs Vue3:核心差异全解析
前端·javascript·vue.js
2601_9495936510 小时前
高级进阶React Native 鸿蒙跨平台开发:LinearGradient 背景渐变与主题切换
react native·react.js·harmonyos
C澒10 小时前
前端监控系统的最佳实践
前端·安全·运维开发
xiaoxue..10 小时前
React 手写实现的 KeepAlive 组件
前端·javascript·react.js·面试
摘星编程10 小时前
在OpenHarmony上用React Native:自定义useHighlight关键词高亮
javascript·react native·react.js
hhy_smile10 小时前
Class in Python
java·前端·python
小邓吖10 小时前
自己做了一个工具网站
前端·分布式·后端·中间件·架构·golang