/uniapp-project-cli

近乎0成本 HBuilderX uniapp 转成 vue-cli 工程

Primary LanguageJavaScript

uniapp-project-cli

0 侵入, 不需要使用 hbuildx 来启动由 hbuildx 创建的 uniapp 项目

Quick start

1 全局安装

npm install -g github:meooxx/uniapp-project-cli
# 如果你已将项目维护到内网gitlab
# npm install -g git+ssh://仓库ssh-url
# npm install -g git+https://仓库https

2 启动项目

unilaunch . -c dev:mp-weixin

CLI

Usage: unilaunch <path> --cmd <cmd>

Commands:
  unilaunch     which project dir to run in                                [default]
  unilaunch ls  list all avalible scripts

Positionals:
  path
   [string] [default: *inux 风格项目路径, 绝对路径或者相对运行时的路径, 默认`.`]

Options:
      --help     Show help                                             [boolean]
      --version  Show version number                                   [boolean]
  -c, --cmd
    [string] [required] [default: 启动script,同由vue-cli建立的项目中scripts字段]

Examples:
  unilaunch ./ --cmd dev:mp-weixin  开发环境运行当前目录下项目

cmd 可选项同vuecli项目下scripts中字段, 如 ['dev:mp-weixin', 'build:mp-weixin',
'dev:mp-alipay', 'build:mp-alipay']
path 不区分windows使用, 统一为/root/path/to/project, or ./project

Pros

对于已经使用 hbuildx 创建的小程序项目, 想使用 vue-cli, 以及 vue-cli 支持的特性。 按照 uniapp 官方说法需要将项目做转换 官方回答.即, 将 hbuildx 创建的 project 放到 vue-cli 创建的项目中src目录下。但是这样有个问题, 如果项目已经维护很久还正在迭代开发的话, 这样的迁移成本是巨大的(经历过). 所以有了这个项目,
可直接使用命令行启动项目, 无限接近于vue-cli 的体验
且将提供接近与 0 的转换成vue-cli的方法

Cons

  1. 没有window设备, 待验证
  2. sass, sass-loader: 使用 Dart Sass 替换sass, sass-loader, 可能会因为国内网络原因挂壁, 请自行解决;有部分不常用sass语法有问题如 /deep/。 可自行决定sasssass-loader

Cli 详细说明

unilaunch: 声明在 bin 字段中.-g安装则全局使用
path: 需要编译的 project 目录, 支持绝对路径和相对路径. windowsmacos 使用相同路径格式. 即在windowsmacos都要指定 /User/xxx/project这种类型路径.相对路径 基于当前路径解析. 比如在project 下执行 ./b , 解析为 project/b
-c, --cmd: 一一对应vue-cli创建的uniapp项目下package.jsonscripts里的字段. 如 dev:h5, dev:mp-weixin 等等
实际场景 如有项目 /User/xxx/project/b, 想要启动项目 b, 可以进入到 b 目录中执行 unilaunch . -c dev:h5, 或者 unilaunch /User/xxxproject/b -c dev:h5

进度

  • 完成所有功能并发布正式版和发布到npm
  • 可以在项目维度自行维护package.json依赖
  • 100% 支持vue-cli项目中scripts字段
  • 正常启动项目