脚手架开发【实战教程】prompts + fs-extra

devtools/2025/2/10 23:13:41/

创建项目

  • 新建文件夹 mycli_demo

  • 在文件夹 mycli_demo 内新建文件 package.json

    {"name": "mycli_demo","version": "1.0.0","bin": {"mycli": "index.js"},"author": "","license": "ISC","description": "","dependencies": {"fs-extra": "^11.3.0","prompts": "^2.4.2"}
    }
    
  • 新建文件 templates\react\package.json

    {"name": "your-project-name","version": "1.0.0","description": "react + ts + vite 项目模板","main": "index.js","scripts": {"dev": "vite"},"keywords": [],"author": "","license": "ISC"
    }
    
  • 新建文件 templates\vue\package.json

    {"name": "your-project-name","version": "1.0.0","description": "vue + ts + vite 项目模板","main": "index.js","scripts": {"dev": "vite"},"keywords": [],"author": "","license": "ISC"
    }
    
  • 新建文件 index.js

    #!/usr/bin/env node// prompts 用于与用户进行交互
    const prompts = require("prompts");// fs-extra 用于文件操作
    const fse = require("fs-extra");// path 用于处理文件路径
    const path = require("path");// 定义项目模板路径
    const templateDir = path.join(__dirname, "templates");// 定义交互问题
    const questions = [{type: "select",name: "projectType",message: "请选择项目类型:",choices: [{ title: "vue", value: "vue" },{ title: "react", value: "react" },],initial: 0,},{type: "text",name: "projectName",message: "请输入项目名称:",validate: (value) => (value.trim() === "" ? "项目名称不能为空" : true),},{type: "select",name: "packageManager",message: "请选择包管理器:",choices: [{ title: "npm", value: "npm" },{ title: "yarn", value: "yarn" },],initial: 0,},
    ];async function createProject() {try {// 发起交互,并获取用户输入const answers = await prompts(questions);// 解析用户输入的项目信息const { projectType, projectName, packageManager } = answers;// 根据用户输入的项目名称,生成新项目目录。  process.cwd() 用于获取当前工作目录的路径const projectDir = path.join(process.cwd(), projectName);// 检查新项目目录是否已存在if (fse.existsSync(projectDir)) {console.error(`项目目录 ${projectDir} 已存在,请选择其他名称。`);return;}// 创建项目目录fse.ensureDirSync(projectDir);// 根据用户选择,获取目标模板路径const templatePath = path.join(templateDir, projectType);// 复制模板目录到目标目录fse.copySync(templatePath, projectDir);// 根据用户选择更新项目配置const packageJsonPath = path.join(projectDir, "package.json");// 读取 package.json 文件const packageJson = fse.readJsonSync(packageJsonPath);// 更新 package.json 中的项目名称packageJson.name = projectName;// 保存更新后的 package.jsonfse.writeJsonSync(packageJsonPath, packageJson, { spaces: 2 });console.log(`项目 ${projectName} 创建成功!`);console.log(`请进入项目目录:cd ${projectName}`);console.log(`使用 ${packageManager} 安装依赖:${packageManager} install`);} catch (error) {if (error.name === "AbortError") {console.log("用户取消了项目创建。");} else {console.error("创建项目时发生错误:", error);}}
    }// 执行创建项目函数
    createProject();
    

安装依赖

pnpm i

或更新到最新版依赖

pnpm i prompts fs-extra

将本地包链接到全局

主要是为了方便本地调试包

npm link --force

此命令会强制将 mycli 链接到全局 node_modules 目录中,同时在全局 bin 目录中根据 package.json 中定义的 bin 字段创建对应的可执行文件
( --force 会强制覆盖已存在的 mycli 链接和可执行文件)

效果预览

命令行中输入 mycli 回车,便会开启交互,最终根据既定模板完成项目的创建。

在这里插入图片描述
在这里插入图片描述

{"name": "reactDemo","version": "1.0.0","description": "react + ts + vite 项目模板","main": "index.js","scripts": {"dev": "vite"},"keywords": [],"author": "","license": "ISC"
}

更多交互命令

参考 prompts 官网 https://www.npmjs.com/package/prompts

脚手架开发的意义和原理

https://blog.csdn.net/weixin_41192489/article/details/125282893

脚手架的系统管理和发布

https://blog.csdn.net/weixin_41192489/article/details/125298121


http://www.ppmy.cn/devtools/157756.html

相关文章

Pytorch与大模型有什么关系

PyTorch 是 深度学习领域最流行的框架之一,在大模型的训练、推理、优化等方面发挥了重要作用。 大模型(如 GPT、LLaMA、Stable Diffusion)大多是基于 PyTorch 进行开发和训练的。 1. PyTorch 在大模型中的作用 大模型(如 ChatGP…

C++基础知识

目录 一、命名空间 1.1、namespace的价值 1.2、namespace的定义 1.3、命名空间的使用 1.3.1、直接展开命名空间 1.3.2、using 将命名空间中某个成员展开 1.3.3、指定命名空间访问 二、C输入和输出 三、缺省参数 四、函数重载 五、引用 5.1、引用的概念和定义 5.2、…

Windows Docker笔记-Docker容器操作

在文章《Windows Docker笔记-Docker拉取镜像》中,已经拉取成功了ubuntu镜像,本章来讲解如何通过镜像来创建容器并运行容器。 这里再类比一下,加深理解,比如,我们现在想开一个玩具厂,我们的最终目的肯定是想…

Maven 安装配置(完整教程)

文章目录 一、Maven 简介二、下载 Maven三、配置 Maven3.1 配置环境变量3.2 Maven 配置3.3 IDEA 配置 四、结语 一、Maven 简介 Maven 是一个基于项目对象模型(POM)的项目管理和自动化构建工具。它主要服务于 Java 平台,但也支持其他编程语言…

DeepSeek背景下的知识库搭建指南

在人工智能领域,DeepSeek无疑是一个近期的热门话题。作为杭州深度求索(DeepSeek)官方推出的AI助手,DeepSeek凭借其强大的自然语言处理能力、逻辑推理能力和问题解决能力,迅速赢得了广大用户的青睐。随着DeepSeek-V3大模…

从DeepSeek上线亚马逊云科技,看大模型争霸背后的隐形战场

小葳 | 智能进化论 2025年开年,凭借与顶尖模型相当的性能、极高的成本效益与开源模式,DeepSeek系列模型成为搅动全球AI行业的新星。DeepSeek应用上线仅20天,日活就突破了2000万,这让其超越ChatGPT成全球增长最快的AI应用。 Deep…

春节假期旅游热潮下,景区医疗安全如何全面升级?

春节假期旅游热潮下,景区医疗安全如何全面升级? 随着旅游业的不断繁荣,春节假期期间,各大景区再次迎来了游客的高峰期。面对如此庞大的客流量,景区不仅要在服务接待上下功夫,更要将医疗安全保障工作提升到…

如何设置爬虫的延时避免频繁请求?

在Python爬虫开发中,合理设置延时是避免频繁请求、降低被封禁风险的关键策略之一。以下是一些常见的延时设置方法和建议: 1. 使用 time.sleep() 设置固定延时 time.sleep() 是最简单直接的延时方法,通过暂停程序的执行来控制请求频率。例如…