动手制作nodejs命令行工具 iconfont-cli

栏目: Node.js · 发布时间: 6年前

内容简介:在package.json中添加命令入口文件创建index.js,文件顶部声明脚本解释程序并指定为nodejs

自动化开发工作流 使开发者能够将更多的精力和时间放在业务逻辑之上,通常会使用 webpack gulp browser-sync 等CLI工具,而自动化的实现则离不开脚本的编写;对于前端开发工程师而言,能够制作 nodejs 命令行脚本 工具 也成为必须掌握的技能之一。

准备工作

  1. 首先我们创建一个新的项目目录 mkdir iconfont-cli ,并使用 npm init 进行初始化,一路回车即可。
  2. 创建脚本入口文件 index.js , 并在package.json设置 bin 参数, 定义脚本命令名称及入口文件,如下:

在package.json中添加命令入口文件

{
    "name":'iconfont-cli'
    ...
    "bin": {
      "iconfont": "index.js"
    }
    ...
}
复制代码

创建index.js,文件顶部声明脚本解释程序并指定为nodejs

#!/usr/bin/env node

// 代码...
console.log('iconfont cli start');

复制代码
  1. 执行 npm link ,将npm包链接到全局执行环境,从而在任意位置使用命令行都可以直接运行,开发期间可以实时调试,该命令主要做两件事情: 一是为npm包目录创建软链接,将其链到 {prefix}/lib/node_modules/<package> ,二为可执行文件(bin)创建软链接,将其链到 {prefix}/bin/{name}
  2. 控制台输入 iconfont , 如打印 iconfont cli start , 那么恭喜,此时项目初始化完成:blush:

命令交互

基本

命令行交互最核心的两大部分: 输入输出 。在准备工作部分,我们已经通过执行 iconfont 简单命令成功运行脚本并输出log。而通常,我们在执行命令时会传入一些参数供用户进行配置,类似 iconfont --dest xxxx 的形式。命令携带的参数可以在node脚本中通过 process.argv 进行访问,然后解析出参数内容。所幸,目前有很多nodejs插件提供了控制台命令参数的解析,比较流行的是 commander.js 库, 可以使我们方便快捷的实现 参数的解析及帮助文档的输出

npm install commander --save
#!/usr/bin/env node
var program = require('commander');

program
  .version('0.0.1') // 设置版本号
  .option('-d, --dest <path>', '设置目标文件夹')  // 设置dest参数
  .action(function (cmd) {
    console.log(cmd.dest) // 打印用户输入的dest参数
    // ...执行后续的功能
  })

program.parse(process.argv); // 解析命令行参数
复制代码

执行 iconfont -d ./ ,控制台输出 ./

  1. commander默认提供了帮助命令,可以直接通过执行 iconfont --help 或者 iconfont -h 输出

进阶

有时候我们希望通过问答的形式使用户进行一些选择、输入或确认操作,以便可以传达和接收更多的信息

对于这种需求,我们可以借助 Inquirer.js

库进行实现,例如我们在上文的commander中配置了dest文件夹后,希望用户进行二次确认操作,因此我们可以有如下做法:

// 此处略去....
var inquirer = require('inquirer');

program
  .version('0.0.1') // 设置版本号
  .option('-d, --dest <path>', '设置目标文件夹')  // 设置dest参数
  .action(function (cmd) {
    console.log(cmd.dest) // 打印用户输入的dest参数
    inquirer.prompt([
      {
        type:'confirm',
        name:'destOk',
        message:'确认使用目标文件夹:' + cmd.dest
      }
    ]).then(function(answers){
      console.log(answers.destOk) // true或false
      // ...执行后续的功能
    })
  })
  
// 此处略去...
复制代码

执行 iconfont -d ./ ,效果如下:

动手制作nodejs命令行工具 iconfont-cli

集成 webfonts-generator

webfonts-generator 支持通过svg文件制作出css字体图标

npm install webfonts-generator --save
#!/usr/bin/env node
var program           = require('commander');
var inquirer          = require('inquirer');
var webfontsGenerator = require('webfonts-generator');
var path              = require('path');
var fs                = require('fs');

// 遍历查询SVG文件
function findSvgs(folder, list){
  list = list || [];
  try {
    var files = fs.readdirSync(folder);
    for(var i=0; i<files.length; i++){
      (function(){
        var fileName = files[i],
            filePath = path.join(folder, fileName),
            stats    = fs.statSync(filePath);
        if(!stats.isFile()){
          return findSvgs(filePath, list);
        } else if(path.extname(filePath) === '.svg'){
          list.push(filePath);
        }
      })(i);
    }
  } catch (error) {
    console.error(error);
  }
  return list;
}

program
  .version('0.0.1') // 设置版本号
  .option('-d, --dest <path>', '设置目标文件夹')  // 设置dest参数
  .action(function (cmd) {

    var currentFolder = process.cwd(); // 当前命令执行的目录
    var destFolder    = path.isAbsolute(cmd.dest) ? cmd.dest : path.join(currentFolder,cmd.dest); // 目标目录, 需区分是否为绝对路径

    inquirer.prompt([
      {
        type: 'confirm',
        name: 'destOk',
        message: '确认使用目标文件夹:' + destFolder
      }
    ]).then(function(answers){
      
      // 用户确认后执行后续的功能
      if(answers.destOk){

        webfontsGenerator({
          files: findSvgs(currentFolder),
          dest: cmd.dest,
          html: true
        }, function(error) {
          if (error) {
            console.log('Fail!', error);
          } else {
            console.log('Done!');
          }
        })
  
      }
      
    })
  })

program.parse(process.argv);
复制代码
  1. 进入svg文件所在的文件夹,执行命令 iconfont -d ./iconfont ,即可生成图标相关的各类文件以及html预览

发布与使用

至此我们成功完成了一个简单的命令行工具 iconfont-cli ,接下来我们可以将其发布的npm仓库供其他开发者下载使用,具体步骤如下:

  1. 首先我们需要在www.npmjs.com/注册账户,之后使用 npm adduser 进行登录,需填写Username、Password、Email相关信息.
  2. 检查package.json设置,如author、license、version、homepage等相关信息,参考package.json属性详解
  3. 发布 npm publish ,此时我们可能会遇到下面截图的问题,说明iconfont-cli已经被其他人发布过了,所以要换个名字进行发布,直接修改package.json中的name即可.
动手制作nodejs命令行工具 iconfont-cli
4. 成功发布之后,可以通过 npm install -g iconfont-cli

全局安装使用


以上所述就是小编给大家介绍的《动手制作nodejs命令行工具 iconfont-cli》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

.NET设计规范

.NET设计规范

克瓦林纳 / 葛子昴 / 人民邮电出版社 / 2006-7 / 49.00元

本书为框架设计师和广大开发人员设计高质量的软件提供了权威的指南。书中介绍了在设计框架时的最佳实践,提供了自顶向下的规范,其中所描述的规范普遍适用于规模不同、可重用程度不同的框架和软件。这些规范历经.net框架三个版本的长期开发,凝聚了数千名开发人员的经验和智慧。微软的各开发组正在使用这些规范开发下一代影响世界的软件产品。. 本书适用于框架设计师以及相关的专业技术人员,也适用于高等院校相关专业......一起来看看 《.NET设计规范》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具