這裏先簡單瞭解一下基礎知識,接下來會基於typescript和rollup參考寫一個較爲完整的腳手架(動態模板),如下只能拉取較爲簡單的靜態模板。javascript
這裏假設咱們的腳手架名字是ds-cli,如下都用這個名字。咱們在命令行使用腳手架命令爲ds前端
//這裏是main.js
#!/usr/bin/env node
// --這種用法是爲了防止操做系統用戶沒有將node裝在默認的/usr/bin路徑裏。當系統看到這一行的時候,
// 首先會到env設置裏查找node的安裝路徑,再調用對應路徑下的解釋器程序完成操做。
//這裏是package.json
"bin": {
"ds": "./main.js"
}
複製代碼
const cmd = require("commander");
// 好比咱們想執行ds init **的命令,想出現「初始化組件模板」的描述
// action是執行這個命令後續的回調,...args是後面**的參數
cmd
.command('init')
.description('初始化組件模板')
.action((...args) => {});
//解析命令行
cmd.parse(process.argv);
複製代碼
咱們經過詢問用戶來得到必定的交互,這樣能夠知道用戶須要什麼vue
//好比咱們在上面那個action裏面搞事情,即ds init以後問用戶
...action((...args)=>{
inquirer
.prompt([
{
name: "description",
message: "請輸入項目描述"
},
{
name: "author",
message: "請輸入做者名稱"
}
]).then(answers=>{
//在這裏得到上面的答案
console.log(answers.description,answers.author)
})
})
複製代碼
const download = require("download-git-repo");
// 第一個git地址,第二個name是git clone下來後的名字...
download(
"https://github.com/yokiyokiyoki/vue-fullpage.git#master",
name,
{ clone: true },
err => {
...
}
);
複製代碼
//這個是經過download-git-repo拉下來的package.json
{
"author":"{{author}}",
"description":"{{description}}"
}
複製代碼
//經過詢問拿到的answers
const meta = {
name,
description: answers.description,
author: answers.author
};
const fileName = `${name}/package.json`;
//判斷一下是否有這個文件
if (fs.existsSync(fileName)) {
const content = fs.readFileSync(fileName).toString();
const result = handlebars.compile(content)(meta);
fs.writeFileSync(fileName, result);
}
複製代碼
const spinner = ora("正在下載模板...");
spinner.start();
spinner.succeed();
複製代碼
#!/usr/bin/env node
// --這種用法是爲了防止操做系統用戶沒有將node裝在默認的/usr/bin路徑裏。當系統看到這一行的時候,
// 首先會到env設置裏查找node的安裝路徑,再調用對應路徑下的解釋器程序完成操做。
const program = require("commander");
const download = require("download-git-repo");
const inquirer = require("inquirer");
const handlebars = require("handlebars");
const fs = require("fs");
const ora = require("ora");
const chalk = require("chalk");
const symbols = require("log-symbols");
program
.version("0.0.1", "-v, --version")
.command("init <name>")
.action(name => {
if (fs.existsSync(name)) {
// 錯誤提示項目已存在,避免覆蓋原有項目
console.log(symbols.error, chalk.red("項目已存在"));
return;
}
inquirer
.prompt([
{
name: "description",
message: "請輸入項目描述"
},
{
name: "author",
message: "請輸入做者名稱"
}
])
.then(answers => {
download(
"https://git.datatub.com:Uranus/general-template#master",
name,
{ clone: true },
err => {
const spinner = ora("正在下載模板...");
spinner.start();
if (!err) {
spinner.succeed();
const meta = {
name,
description: answers.description,
author: answers.author
};
const fileName = `${name}/package.json`;
if (fs.existsSync(fileName)) {
const content = fs.readFileSync(fileName).toString();
const result = handlebars.compile(content)(meta);
fs.writeFileSync(fileName, result);
}
console.log(symbols.success, chalk.green("項目初始化完成"));
} else {
spinner.fail();
console.log(symbols.error, chalk.red(`拉取遠程倉庫失敗${err}`));
}
}
);
});
});
//解析命令行
program.parse(process.argv);
複製代碼
前端如何搭建一個成熟的腳手架java