实现vue-cli(三):vue-cli问询和拷贝

一、vue-cli的简单实现

  1. 新建一个vue-cli-sample的文件夹,该文件夹下打开命令行,输入yarn init生成package.json文件。
  2. package.json文件中新增一行"bin": "cli.js"指定cli.js作为入口文件。
  3. 新建cli.js文件,第一行写入#!/usr/bin/env node。因为Node cli应用入口文件必须有这样的文件头,如果是linux或者macOS系统还需要通过命令行输入chomd 755 cli.js修改读写权限。
  4. 命令行输入yarn add inquirer ejs --dev安装用户问询模块和模板渲染引擎。
  5. cli.js文件里写入以下代码。
#!/usr/bin/env node

// 1、先询问用户信息
// 2、指定模板路径和生成路径
// 3、读取模板文件,生成对应文件
const fs = require('fs');
const path = require('path');
const inquirer = require('inquirer');
const ejs = require('ejs');

// 在命令行询问用户输入信息
inquirer.prompt([
  {
    type: 'input',
    name: 'name', // 用户输入内容赋值给name
    message: 'Project name?', // 控制台显示提示语
  }
])
.then(anwsers => { // aswers为命令行用户输入的信息
  const tmplDir = path.join(__dirname, 'templates');
  const destDir = process.cwd(); // 当前命令行所在的目录下

  // 将模板下的文件全部转换到目标目录
  fs.readdir(tmplDir, (err, files) => {
    if (err) throw err;
    files.forEach(file => {
      // 通过ejs模板引擎渲染文件
      ejs.renderFile(path.join(tmplDir, file), anwsers, (err, result) => {
        if (err) throw err;

        // 将结果写入目标文件路径
        fs.writeFileSync(path.join(destDir, file), result);
      });
    });
  });
});
  1. 在当前目录下新建templates目录,放入一个test.js文件,文件内容<%= name %>指定用ejs语法填充数据。
  2. 命令行输入yarn link将当前vue-cli-sample(项目名)链接到全局。
  3. 新建空文件夹,该文件夹下打开命令行输入刚才链接的项目名vue-cli-sample即可执行该模块。然后按提示输入名字假设为test回车,会看到该空文件夹生成了test.js内容为test,则代表成功。

二、优化

将上面templates文件夹里的内容替换成我们前两步(实现vue-cli(一):gulp自动化构建实现vue-cli(二):webpack实现项目打包)生成的 gulpfile.js、webpack配置内容和项目内容。此时vue-cli自动生成的不止一两个文件,文件多了会有几个问题,我们分别解决下。

  1. fs.readdir只会读取一层目录,如果templates里有很多子目录,则ejs渲染目录会失败。我们用fs.stat方法增加个类型检测,如果是文件夹则继续遍历。
  2. 遍历到新文件夹还要创建,不然最后生成文件会找不到文件夹。用yarn add mkdirp --dev添加对应插件。
  3. 图片等文件是不需要用ejs进行渲染的,否则可能会错误地把<%=解析成填充内容,此处判断为图片就直接copy。
#!/usr/bin/env node

// 1、先询问用户信息
// 2、指定模板路径和生成路径
// 3、读取模板文件,生成对应文件
const fs = require('fs');
const path = require('path');
const inquirer = require('inquirer');
const ejs = require('ejs');
const mkdirp = require('mkdirp');

// 在命令行询问用户输入信息
inquirer.prompt([
  {
    type: 'input',
    name: 'name',
    message: 'Project name?'
  }
])
.then(anwsers => { // aswers为命令行用户输入的信息
  const tmplDir = path.join(__dirname, 'templates');
  const destDir = process.cwd();

  // 将模板下的文件全部转换到目标目录
  const handleFiles = (dir, rootDir) => {
    fs.readdir(dir, (err, files) => {
      if (err) throw err;
      files.forEach(file => {
        let filePath = path.resolve(dir, file);
        let targetPath = path.join(destDir, path.relative(rootDir, filePath));
        fs.stat(filePath, (err, stats) => {
          if (err) throw err;
  
          if (stats.isDirectory()) {
            mkdirp(targetPath).then(() => {
              handleFiles(filePath, rootDir);
            });
            return;
          }
          if (stats.isFile()) {
            // 如果是图片则直接copy不需要ejs渲染,不然文件中带有<%可能会出错
            if (/\.jpg$|\.gif$|\.png$|\.ico$/.test(filePath)) {
              fs.copyFileSync(filePath, targetPath);
              return;
            }
            // 通过模板引擎渲染文件
            ejs.renderFile(filePath, anwsers, (err, result) => {
              if (err) throw err;
  
              // 将结果写入目标文件路径
              fs.writeFileSync(targetPath, result);
            });
          }
        });
      });
    });
  }

  handleFiles(tmplDir, tmplDir);
});

最后,在空文件夹命令行执行vue-cli-sample自动生成对应资源,然后yarn install安装依赖包,执行yarn gulp develop打开浏览器页面正常即代表成功。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容