Vite + TypeScript + Node 开发一个初始化项目的脚手架

以下是一个简单的脚手架项目初始化脚本示例,使用了Node.js和Vite来创建一个带有TypeScript支持的新项目骨架。




const fs = require('fs-extra');
const path = require('path');
const execa = require('execa');
 
// 创建项目目录结构
function createDirectoryStructure(root) {
  fs.mkdirpSync(path.join(root, 'src'));
  fs.mkdirpSync(path.join(root, 'public'));
}
 
// 初始化package.json
function initPackageJson(root, projectName) {
  const pkg = {
    name: projectName,
    version: '0.1.0',
    scripts: {
      dev: 'vite',
    },
    dependencies: {
      react: '^17.0.1',
      'react-dom': '^17.0.1',
    },
    devDependencies: {
      vite: '^2.0.0',
      typescript: '^4.1.3',
    },
  };
  fs.writeFileSync(path.join(root, 'package.json'), JSON.stringify(pkg, null, 2));
}
 
// 创建TypeScript配置文件
function createTsConfig(root) {
  const tsConfig = {
    compilerOptions: {
      target: 'esnext',
      module: 'esnext',
      jsx: 'react',
      moduleResolution: 'node',
      lib: ['esnext', 'dom'],
      outDir: 'dist',
      skipLibCheck: true,
    },
    include: ['src/**/*.tsx', 'src/**/*.ts'],
  };
  fs.writeFileSync(path.join(root, 'tsconfig.json'), JSON.stringify(tsConfig, null, 2));
}
 
// 创建Vite配置文件
function createViteConfig(root) {
  const viteConfig = `
import { defineConfig } from 'vite';
import react from '@vitejs/plugin-react';
 
// https://vitejs.dev/config/
export default defineConfig({
  plugins: [react()],
});
`;
  fs.writeFileSync(path.join(root, 'vite.config.ts'), viteConfig);
}
 
// 初始化git仓库
function initGitRepo(root) {
  process.chdir(root);
  execa('git', ['init']);
  execa('git', ['add', '.']);
  execa('git', ['commit', '-m', 'Initial commit']);
}
 
// 主函数
function createProject(projectName) {
  const root = path.join(process.cwd(), projectName);
  createDirectoryStructure(root);
  initPackageJson(root, projectName);
  createTsConfig(root);
  createViteConfig(root);
  initGitRepo(root);
}
 
// 使用脚手架创建项目
createProject('my-vite-project');

这段代码首先定义了创建目录结构、初始化package.json、创建TypeScript和Vite配置文件以及初始化Git仓库的函数。最后通过createProject函数来执行这些步骤,创建一个新的项目。

注意:在实际应用中,脚手架通常会更复杂,包括命令行界面(CLI)、交互式提示等功能,但这个示例提供了一个基本的项目初始化流程。

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日