pnpm、monorepo分包管理、多包管理、npm、vite、前端工程化、保姆级教程

浅尝pnpm monorepo 多包管理方案

💡tips: 创建pnpm monorope多包管理框架流程

初始化
bash 复制代码
mkdir taurus & cd taurus
pnpm init
创建基础文件
  1. 创建文件pnpm-workspace.yaml
yaml 复制代码
packages:

  - 'packages/**'
  1. 创建文件夹packages/
bash 复制代码
-packages/
-package.json
-pnpm-workspace.yaml
创建子项目
  1. 创建子项目@taurus/three

tips:创建项目时将项目名称设置为目标名称(@taurus/name 方便区分共有包和自定义包,不做强制要求),可查看 packages.json 中的name字段进行验证

bash 复制代码
cd packages
pnpm create vite three --template vue
  1. 创建子项目@taurus/utils
bash 复制代码
cd packages
mkdir utils & cd utils
npm init
  1. 添加子项目引用
bash 复制代码
pnpm add @tautus/utils --filter @taurus/three -wP

添加成功后验证方法

@taurus/three-ts配置引用目录别名 @

  1. 在vite.config.ts中添加 alias

    复制代码
    import { defineConfig } from "vite";
    import vue from "@vitejs/plugin-vue";
    import path from 'path';
    // https://vitejs.dev/config/
    export default defineConfig({
      plugins: [vue()],
      resolve:{
        alias:{
          "@":path.resolve(__dirname,"src"),
          'components': path.resolve(__dirname, './src/components'), // 设置 'components' 指向 src/components 目录
        }
      }
    });
  2. 解决使用nodeAPI时ts报错问题,下载node类型函数

    bash 复制代码
    pnpm add @types/node -wD
  3. 解决文件中使用@引用是的ts报错,在tsconfig.json中设置@别名

    复制代码
    {
      "compilerOptions":{
        "baseUrl": ".", // 这个选项中指定了相对于哪个目录解析别名
        "paths":{
          "@/*": ["src/*"] // 这里设置别名@指向src目录下的文件
         }
      }
    }

支持less

pnpm 复制代码
pnpm add less less-loader --filter @taurus/three-ts -w

配置vite.config.ts

typescript 复制代码
{
  ...
  css:{
   preprocessorOptions: {
      less: {
        math: "always", // 括号内才使用数学计算
        globalVars: {
          // 全局变量
          mainColor: "red",
        },
      },
    },
  }
}

组件中使用

复制代码
<style lang="less" scoped>
  .classA{
    .p1{color:red;}
  }
</style>

接下来开始编写你颠覆时代的代码吧

欢迎各位猿佬留言交流

相关推荐
前端 贾公子几秒前
从入门到实践:前端 Monorepo 工程化实战(4)
前端
菩提小狗3 分钟前
Sqlmap双击运行脚本,双击直接打开。
前端·笔记·安全·web安全
前端工作日常14 分钟前
我学习到的AG-UI的概念
前端
韩师傅19 分钟前
前端开发消亡史:AI也无法掩盖没有设计创造力的真相
前端·人工智能·后端
XiaoYu200234 分钟前
第12章 支付宝SDK
前端
双向331 小时前
RAG的下一站:检索增强生成如何重塑企业知识中枢?
前端
拖拉斯旋风1 小时前
从零开始:使用 Ollama 在本地部署开源大模型并集成到 React 应用
前端·javascript·ollama
asing1 小时前
🤯 为什么我的收银台在鸿蒙系统“第一次返回”死活拦不住?一次差点背锅的排查实录
前端·harmonyos
德育处主任1 小时前
『NAS』在群晖部署图片压缩工具-Squoosh
前端·javascript·docker
Hao_Harrision1 小时前
50天50个小项目 (React19 + Tailwindcss V4) ✨| ThreeDBackgroundBoxes(3D背景盒子组件)
前端·3d·typescript·react·tailwindcss·vite7