react+ts+antd项目搭建

前言: 基于ts语言创建react项目,node版本是v16.14.2

一、 脚手架创建项目

  1. 全局安装
 npm install -g creacte-react-app
  1. 创建项目file-management,ts需要添加–template typescript
npx create-react-app file-management --template typescript

二、 添加craco.config.js配置文件,类似于vue的vue.config.js文件

  1. 安装
npm i -D @craco/craco
  1. 在项目根目录添加craco.config.js文件并添加路径别名
const path = require('path')

module.exports = {
  // webpack 配置
  webpack: {
    // 配置别名
    alias: {
      '@': path.resolve(__dirname, 'src')
    }
  }
}
  1. 修改 package.json 中的脚本命令

修改前:

"scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject"
  },

修改后:

"scripts": {
    "start": "craco start",
    "build": "craco build",
    "test": "craco test",
    "eject": "craco eject"
  },
  1. 配置路径识别,在根目录tsconfig.json文件中添加baseUrl和paths
{
  "compilerOptions": {
    "target": "es5",
    "lib": [
      "dom",
      "dom.iterable",
      "esnext"
    ],
    "allowJs": true,
    "skipLibCheck": true,
    "esModuleInterop": true,
    "allowSyntheticDefaultImports": true,
    "strict": true,
    "forceConsistentCasingInFileNames": true,
    "noFallthroughCasesInSwitch": true,
    "module": "esnext",
    "moduleResolution": "node",
    "resolveJsonModule": true,
    "isolatedModules": true,
    "noEmit": true,
    "jsx": "react-jsx",
    "baseUrl": "./",
    "paths": {
      "@/*": ["src/*"]
    }
  },
  "include": [
    "src"
  ]
}

更多配置参见craco配置文档

三、使用第三方组件库antd

需要注意的是antd是按需导入的,react并不能像vue一样把组件全部引用并注册。所以在react中使用antd只能是需要什么组件在页面中引入使用

  1. 安装
npm install antd --save
  1. 引入,以app.tsx为例
import { ConfigProvider } from 'antd';
import './App.css';

function App() {
  return (
    <ConfigProvider>
      
    </ConfigProvider>
  );
}

export default App;

四、使用less

  1. 安装,我们使用craco方式
npm i craco-less
  1. 在craco.config.js文件中添加配置
const CracoLessPlugin = require('craco-less')

module.exports = {
  plugins:[
    {
      // less
      plugin: CracoLessPlugin,
      options: {
        // resolve-url-loader只对sass生效,craco-less默认使用sass配置,所以这里手动过滤掉resolve-url-loader
        modifyLessRule: (lessRule) => {
          lessRule.use = lessRule.use.filter(
            (i) => !i.loader.includes('resolve-url-loader')
          );
          return lessRule;
        },
      },
    },
  ],
}
  1. 把app.css改为app.less并在app.tsx中引入
    在这里插入图片描述

五、使用路由

  1. 安装
npm install react-router react-router-dom
  1. 使用 app.tsx
import { ConfigProvider } from 'antd';
import { BrowserRouter as Router } from 'react-router-dom';
import './App.less';

function App() {
  return (
    <Router>
      <ConfigProvider>

      </ConfigProvider>
    </Router>
  );
}

export default App;

相关推荐

  1. rollup + typescript 项目

    2024-07-10 20:26:05       48 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-10 20:26:05       52 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-10 20:26:05       54 阅读
  3. 在Django里面运行非项目文件

    2024-07-10 20:26:05       45 阅读
  4. Python语言-面向对象

    2024-07-10 20:26:05       55 阅读

热门阅读

  1. Linux C++ 047-设计模式之责任链模式

    2024-07-10 20:26:05       20 阅读
  2. 常用Docker命令

    2024-07-10 20:26:05       22 阅读
  3. Postman与世界相连:集成第三方服务的全面指南

    2024-07-10 20:26:05       21 阅读
  4. 3033.修改矩阵

    2024-07-10 20:26:05       19 阅读
  5. 架构面试-数据库优化问题

    2024-07-10 20:26:05       19 阅读
  6. 精通Sklearn时间序列分析:预测未来的艺术

    2024-07-10 20:26:05       24 阅读
  7. OpenHarmony移植小型系统exynos4412(一)

    2024-07-10 20:26:05       19 阅读