最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • ✋手摸手系列(一/1): vite react typescript reactHook mobx(非脚手架)(从0开始)(包含路由权限控制)

    正文概述 掘金(wowhoo)   2021-04-25   875

    参考文献:vitejs.dev/config/#esb… 项目地址:github.com/wowhoonet/v…

    后台系列目录

    1. ✋手摸手系列(一/1): vite react typescript reactHook mobx(非脚手架)(从0开始)(包含路由权限控制)

    2. ✋手摸手系列(一/2): vite react typescript reactHook mobx(非脚手架)(从0开始):路由和权限搭建

    !!!vite 比较易懂,不讲概念了直接开整

    搭建开始

    1. 初始化项目

    mkdir vite_react_mobx
    cd vite_react_mobx
    yarn init -y
    
    1. 安装依赖

    开发依赖

    yarn add vite typescript -D
    

    生产依赖

    yarn add react react-dom
    

    package.json 如下所示

    {
      "name": "vite_react_mobx",
      "version": "1.0.0",
      "main": "index.js",
      "license": "MIT",
      "scripts": {
        "dev": "vite"
      }, // 加入执行脚本
      "devDependencies": {
        "typescript": "^4.2.4",
        "vite": "^2.2.1"
      },
      "dependencies": {
        "react": "^17.0.2",
        "react-dom": "^17.0.2"
      }
    }
    
    1. 开发开始

    根目录新建 index.html, index.tsx 两个文件

    ✋手摸手系列(一/1): vite react typescript reactHook mobx(非脚手架)(从0开始)(包含路由权限控制) 可以看到我在 body 元素下面引入了 index.tsx 文件,需要注意的是 type="module"

    <script type="module" src="./index.tsx"></script>
    

    在 index.tsx 开始编写 typescript 代码

    {
      "name": "vite_react_mobx",
      "version": "1.0.0",
      "scripts": {
        "dev": "vite", 
      },
      "main": "index.js",
      "license": "MIT",
      "devDependencies": {
        "typescript": "^4.2.4",
        "vite": "^2.2.1"
      },
      "dependencies": {
        "@types/node": "^14.14.37",
        "@types/react": "^17.0.3",
        "@types/react-dom": "^17.0.3",
        "@types/react-router": "^5.1.13",
        "@types/react-router-dom": "^5.1.7",
        "react": "^17.0.2",
        "react-dom": "^17.0.2"
      }
    }
    

    开始开发我们的 index.tsx 文件咯

    import React from 'react';
    import ReactDom from 'react-dom';
    
    ReactDom.render(
      <div>我是 vite</div>,
      document.querySelector('#app')
    )
    

    执行我们的 命令

    yarn dev
    

    ✋手摸手系列(一/1): vite react typescript reactHook mobx(非脚手架)(从0开始)(包含路由权限控制)

    正文开始

    1. 配置 vite(讲每一个配置的目的和作用)
    2. 配置 tsconfig
    3. 搭建项目框架

    vite 配置

    根目录新建 vite.config.ts

    开始配置 vite.config.ts

    const path = require("path");
    import reactRefresh from "@vitejs/plugin-react-refresh"; // 热更新
    import { defineConfig } from 'vite'; // 自带的默认配置
    import html from 'vite-plugin-html'; // 生成自定义 html,主要是在 html 中插入ico,title 等自定义动作
    import vitePluginImp from 'vite-plugin-imp'; // 按需加载
    import autoprefixer from 'autoprefixer'; // 浏览器兼容 css自动加前缀(比如::wikit-xxx)
    
    const isDev = process.env.NODE_ENV === 'development';
    const isProd = process.env.NODE_ENV === 'production';
    const port = 3000; 
    
    export default  defineConfig({
      root: process.cwd(), // index.html 的目录,默认查找的目录 
      base: "/", // 静态资源的目录
      mode: process.env.NODE_ENV, // 'production' | 'development' | 'none'
      define: {
        "process.env": {
          BUILD_ENV: process.env.BUILD_ENV || "beta", // 自定义参数
        },
      }, // 定义
      plugins: [
        reactRefresh(), // 热更新插件
        html({
          minify: true,
          inject: {
            injectData: {
              title: 'injectData title'
            }
          } // 注入 title,并压缩
        }),
        vitePluginImp({
          libList: [
            {
              libName: 'antd',
              style: (name) => {
                return`antd/lib/${name}/style/index.css`
              },
            }
          ]
        }) // 配置 antd 按需加载
      ], // 插件
      publicDir: 'public', // 静态资源目录,打包原封不动的目录
      resolve: {
        alias: {
          "@": path.resolve("src"),
        }, // 别名
        dedupe: [], // 重复依赖
        conditions: [], // 导出 计算
        extensions: [".js", ".jsx", ".ts", ".tsx", ".json"], // 省去拓展名的类型
      },
      css: {
        modules: {
          // localsConvention: "camelCaseOnly", // 模块 css 导出时用 驼峰(我不喜欢)
        },
        postcss: {
          // parser
          plugins: [
            autoprefixer({
              "overrideBrowserslist": ['last 2 versions'],
              grid: true
            }) // 自动前缀
          ]
        },
        preprocessorOptions: {
    
        },
      },
      logLevel: isDev ? 'info' : 'error',
      server: {
        hmr: true,
        port: port,
        open: true,
        proxy: {
          "^/api": {
            target: "https://test.api.order.iduoliao.cn",
            changeOrigin: true,
            ws: false,
            'secure': false,
            rewrite: (path) => path.replace(/^\/api/, '')
          },
        },
      }, // devServer 配置
      build: {
        // target: ""
        outDir: 'dist',
        assetsInlineLimit: 4096, // 在多少 kb 使用 base64
        cssCodeSplit: true, // css 拆分
        sourcemap: isDev ? 'inline' : false,
        minify: isProd ? 'terser': 'esbuild', // 使用打包器 terser打包效果好,但是打包速度慢  esbuild打包快
        terserOptions: {
          compress: true,
          ie8: false,
          format: {
            comments: false,
          }
        },
        cleanCssOptions: {
          level: 1,
        },
        write: true, // 将依赖资源写入到磁盘里面
        brotliSize: true, // 压缩报告
        chunkSizeWarningLimit: 500, //
      },
      optimizeDeps: {
        // entries: // 指定入口 index.html,
        
      }
    });
    
    

    ts 配置

    根目录新建 tsconfig.json

    {
      "isolatedModules": true, // 每个文件都是单独的模块
      "compilerOptions": {
        "target": "esnext", // 目标为 esnext 版本
        "lib": ["dom", "esnext"], // 依赖库
        "jsx": "react", // jsx 编译成 react
        "module": "esnext", 
        "allowJs": true, 
        "moduleResolution": "node",
        "isolatedModules": false,
        "emitDecoratorMetadata": true, // 使用装饰器
        "experimentalDecorators": true,
        "noImplicitAny": true,
        "noImplicitThis": false,
        "strictNullChecks": false,
        "removeComments": false, // 移除注释
        "suppressImplicitAnyIndexErrors": true,
        "allowSyntheticDefaultImports": true,
        "typeRoots": ["node_modules/@types", "global.d.ts"], // 类型推导文件
        "baseUrl": "./", 
        "paths": {
          "@/*": ["src/*"]
        }, // 将 @/* 编译成 src/*
        "esModuleInterop": true,
        "types": ["vite/client", "node"], // 类型推导库
      },
      "exclude": ["node_modules", "dist"] // 哪些文件不需要打包
      // "include": [
      //   "**/*.tsx",
      //   "**/*.ts",
      // ]
    }
    

    需要再补充一下依赖 package.json

    {
      "devDependencies": {
        "typescript": "^4.2.4",
        "vite": "^2.2.1",
        "@vitejs/plugin-react-refresh": "^1.3.1",
        "vite-plugin-html": "^2.0.3",
        "vite-plugin-imp": "^2.0.5"
      },
      "dependencies": {
        "@types/node": "^14.14.37",
        "@types/react": "^17.0.3",
        "@types/react-dom": "^17.0.3",
        "@types/react-router": "^5.1.13",
        "@types/react-router-dom": "^5.1.7",
        "react": "^17.0.2",
        "react-dom": "^17.0.2",
        "autoprefixer": "^10.2.5",
        "less": "^4.1.1",
        "less-loader": "^8.0.0"
      }
    }
    

    重新安装依赖

    yarn 
    

    创建 view 页面文件夹

    ✋手摸手系列(一/1): vite react typescript reactHook mobx(非脚手架)(从0开始)(包含路由权限控制)

    将主目录的 index.tsx 修改一下 如下:

    import App from '@/view/App';
    import React from 'react';
    import ReactDom from 'react-dom';
    
    ReactDom.render(
      <App></App>,
      document.querySelector('#app')
    )
    
    yarn dev
    

    !恭喜,这时候已经可以看到效果了

    太晚了,明天继续写 权限控制, see u, 第一次写文章,有什么问题或者不理解的或者不对的可以评论告诉我, 代码晚点上传 github,持续更新


    起源地下载网 » ✋手摸手系列(一/1): vite react typescript reactHook mobx(非脚手架)(从0开始)(包含路由权限控制)

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元