一个工程的生命周期:
yeoman的基本概念
yeoman使用说明
npm install --global yo
npm install --global generator-webapp
mkdir project-name
cd project-name
yo webapp
npm run start
自定义Generator
首先配置Generator需要有严格的文件结构
|_ generators/ ............................. 生成器目录
| |_ app/ ............................. 默认生成器目录
| |_ index.js ............................. 默认生成器实现
|_ package.json ............................. 模块包配置文件
使用yeoman实现自己的脚手架
创建文件结构并且初始化项目
创建文件夹名字必须是generator-xxx
npm init -y //初始化项目
配置文件结构注意:文件结构名字不能改变
npm install yeoman-generator
const Generator = require("yeoman-generator");const path = require("path");
const fs = require("fs");module.exports = class extends Generator {prompting() {// promisereturn this.prompt([{type: "input",name: "title",message: "Project name:",default: this.appname,},]).then((answers) => {this.answers = answers;});}writing() {// // 创建单个文件// this.fs.write(// this.destinationPath("temp.txt"),// Math.random().toString()// );// // 创建模板文件// const tmpl = this.templatePath("index.html");// const output = this.destinationPath("index.html");// const context = this.answers;// this.fs.copyTpl(tmpl, output, context);//创建多个模板文件const tmpDir = path.join(__dirname, "templates");fs.readdir(tmpDir, (err, files) => {if (err) throw err;files.forEach((file) => {console.log(file);const tmpl = this.templatePath(file);const output = this.destinationPath(file);const context = this.answers;this.fs.copyTpl(tmpl, output, context);});});}
};
npm link//挂载
npm unlink//卸载
这一块 可以使用yarn去挂载
yarn link//挂载
yarn unlink//卸载
yo xxx//这里的xxx是你最外层定义的generator-xxx文件名
到此即可创建成功!!!
npm init -y
安装命令提示符交互 inquirer
ejs模板npm i ejs inquirer
//配置bin
{"name": "ncl","version": "1.0.0","description": "","main": "index.js","bin": {"ncl": "`./cli.js`"},"scripts": {"test": "echo \"Error: no test specified\" && exit 1"},"keywords": [],"author": "","license": "ISC","dependencies": {"ejs": "^3.1.8","inquirer": "^8.0.0"}
}
#!/usr/bin/env node //这一块必须写 因为这个文件当成脚本去执行,写在第一行
const fs = require("fs");
const path = require("path");
const inquirer = require("inquirer");
const ejs = require("ejs");inquirer.prompt([{type: "input",name: "title",message: "Project name:",},]).then((answers) => {console.log(answers);// 获取模板路径const tmpDir = path.join(__dirname, "templates");// console.log(tmpDir);// 获取命令符窗口的路径const destDir = process.cwd();// console.log(destDir);fs.readdir(tmpDir, (err, files) => {if (err) throw err;files.forEach((file) => {ejs.renderFile(path.join(tmpDir, file), answers, (err, result) => {if (err) throw err;fs.writeFileSync(path.join(destDir, file), result);});});});});
总结:脚手架其实就是通过读写文件,来实现的