buijs
v1.9.31
Published
buijs cli 是用于快速构建BUI工程及模板的命令集, 请仔细阅读说明文档.
Downloads
1,269
Readme
buijs 命令行工具
| 描述 | 修改日期 | | :------------------------------------------------------------ | -----------: | | 新增update命令,修复update平台时,会覆盖index.html,index.js问题 | 2018-2-1 | | 新增NPM开发模式,修改了目录规范,修复无网络无法创建问题 | 2018-3-25 | | 新增buijs update -d 更新工程gulpfile.js package.json app.json | 2018-4-12 | | 修复buijs create 不能在同个工程下创建子工程 | 2018-5-30 | | 新增对相同模板目录的检测,避免重复覆盖 | 2018-8-01 | | 修复输入版本号前必须输入工程名 | 2018-10-31 | | 新增多工程共享 node_modules目录 | 2018-12-07 | | 新增创建新模块命令 buijs create -m 模块名 | 2019-01-22 | | 新增更改数据源命令, 默认是 github. buijs create -f gitee | 2019-03-20 | | 完善创建新模块命令,需要结合最新的 buijs 及 bui-template 使用 | 2019-08-26 | | 新增对工程的node不同版本的区分 | 2020-04-01 | | 更新默认的源为 gitee 国内会快很多 | 2020-04-13 | | 更新bui为1.7.0版本 | 2022-03-01 | | 更新为bui官网数据源 | 2022-08-24 | | 优化获取官方远程模板组件 | 2022-09-10 | | 优化创建缓存 | 2022-10-08 | | 优化node16版本 | 2023-6-2 | | 优化报错 | 2024-5-13 |
重要说明
重大更新,由于 github,gitee 的资源不稳定,数据源迁回 easybui.com 官网,请重新执行 npm install -g buijs
安装命令, 版本要大于 1.9.12。
官网资源第一次需要登录,请先执行 buijs login
,账号密码,如无账号,请先从 easybui.com 免费注册。
如果有报错 Error: options.uri is a required argument
请尝试重新登录, 或者更新 buijs CLI 版本;
另外,模板包里的模板及案例会逐渐减少,模板均已放在网站资源里,更容易找到也较容易维护。
buijs CLI的部分功能跟 百搭-可视化构建开发工具 重叠,我们要打造资源开发一体化,迅速集成,减少各种配置跟依赖的安装,欢迎关注
bui神速
订阅号,以获取最新的官方渠道消息。
一、简介
buijs 是BUI Webapp交互框架 cli命令工程构建工具, 用于快速生成指定平台与模板最新的工程文件.
通过命令行构建,有以下好处:
- 自动获取最新的BUI模板工程;
- 可以指定bui对应的平台版本;
- 可以指定bui的单页模板. ;
- 拥有服务器并支持接口跨域调试;
- 自动编译压缩混淆文件,便于打包部署的安全;
- 支持ES6编译;
- 支持sass编译[取消默认使用];
- 支持less编译;
- 减少对工具的依赖;
- 获取官网远程模板及组件[新功能];
二、安装buijs命令行工具
需要先安装 node环境 才能使用npm命令. 如果下载缓慢,建议先安装淘宝的npm镜像, 把以下命令的npm
换成cnpm
;
windows: 需要右键使用管理员打开终端或者安装 powershell
.
npm install -g buijs
mac: 打开终端, 需要权限,加上sudo,还要输入密码回车确认
$ sudo npm install -g buijs
三、初始化工程目录:
3.1 创建默认Webapp工程, 新版的buijs会针对不同的node版本,创建不同的工程,但是默认不会主动创建sass的编译支持.
# * 创建webapp工程 (demo 为工程名称, 如果没有,则在当前目录)
$ buijs create demo
# * 进入工程目录
$ cd demo
# * 安装依赖
$ npm install
# * 自动打开浏览器并监听js,scss,html等文件的修改
$ npm run dev
# 非必须命令,编译工程,生成dist目录,压缩脚本,样式,图片,用于发布打包的安全, 会清空之前目录,重新根据`src`目录生成. 另外, es6 的模块化 import ,Objece.assign 等方法不要使用, 会导致编译后在部分手机无法运行
$ npm run build
3.1.1 如果需要工程对sass或者less支持
在刚刚创建的demo工程里面再次执行以下命令
$ buijs create -p less # 推荐
$ buijs create -p sass # 不推荐 受各自的环境影响,报错概率大
注意: npm run dev
使用这个命令, 样式的修改都需要在 src/less/style.less
文件. 如果直接修改src/css/style.css
,需要删除src/less
目录,避免style.css被覆盖.
安装时, 如果报 sass 错误, 请先执行 npm remove node-sass
然后再安装依赖. (不推荐 sass)
3.2 自动打开默认浏览器, 修改src 目录的相同文件,就会生成对应的dist文件,用于预览.
http://localhost:port
port
端口自动生成, 一个端口对应一个工程, 如需更改同样是在app.json
配置.
3.3 工程模板预览
默认模板预览 更多本地模板点击这里 BUI模板图片预览
四、接口跨域及配置
接口跨域
打开根目录下的 app.json
,里面有个 proxy
的对象, key值为接口的目录名, target
为域名的host.
假设请求的接口地址为: http://www.easybui.com/api/getDetail/id/123
需要这样配置 proxy :
{
...
"proxy": {
"/api": {
"target": "http://www.easybui.com",
"changeOrigin":true
}
}
...
}
js: 脚本请求使用相对路径, 为了后面更改为正式地址, 建议可以把url部分作为配置项.
var apiUrl = "";
bui.ajax({
url: apiUrl+ "api/getDetail/id/123"
}).then(function(res){
})
服务器的配置说明
打开根目录下的 `app.json ,里面有个 devServer 的对象.
{
"distServer": {
"root": "dist", // 编译的目录
"livereload": true, // 修改自动刷新
"port": 2149 // 端口号,默认第一次随机自动生成
}
}
五、命令列表
注意: 中括号为可选,如果没有采用默认
buijs 命令列表
| 命令行 | 描述 |
| :----------------------------------------------------------------------------------------- | :---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| buijs -v
| 查看当前工具的版本 |
| buijs -h
| 命令帮助信息 |
| buijs create
| 在当前目录创建bui webapp默认工程 |
| buijs create [projectName] [version] [-t templateName] [-p platformName] [-m moduleName]
| 创建工程,支持指定版本,指定模板,指定平台,相同目录下会覆盖 |
| buijs update
| 在当前项目更新 bui为最新webapp版本,只修改bui.css,bui.js不覆盖项目其它内容 |
| buijs update [projectName] [version] [-p platformName] [-d dev]
| 更新bui为某个版本,某个平台, -d 更新为最新的工程模式(dev) |
| buijs list
| 显示可用的版本 |
| buijs list-template
废弃 | 显示可用的模板列表 BUI模板图片预览 |
| buijs list-platform
| 显示可用的平台列表 |
| buijs clear
| 清除下载的模板缓存 |
| buijs create -m 模块名
| 创建新的模块 m = module |
| buijs get id [name]
新 | 创建新的模板,ID,为官网模板或组件的id,例如 https://easybui.com/components/237.html , buijs get 237 会把这个组件下载到 pages/ 目录下,buijs get 237 -s components 指定保存到目录为 pages/components ,buijs get 237 dateselect 重新指定组件名为dateselect |
NPM 命令列表
| 命令行 | 描述 |
| :-------------- | :------------------------------------------------------------------------------------ |
| npm run build
| 编译成可以打包的文件,默认服务器根路径是"dist",所以需要先编译 |
| npm run dev
| 启动服务并打开默认浏览器,支持接口跨域, 并且会自动监听脚本,scss文件,html文件的修改编译 |
六、命令示例
创建某个模板工程 ( main-tab 为模板名称)
可以先查看有什么模板 buijs list-template
, BUI模板图片预览
# 查看有什么模板
$ buijs list-template
# 进入当前工程 demo
$ cd demo
# 替换main模板
$ buijs create -t main-tab
# 新增login模板
$ buijs create -t page-login
# 新增一个新模块 apps
$ buijs create -m apps
# 新增一个新子模块 apps/meeting
$ buijs create -m apps/meeting
创建远程模板[新]
例如 https://easybui.com/components/237.html
# 把这个组件下载到 pages/ 目录下
buijs get 237
# 指定保存到目录为 pages/components
buijs get 237 -s components
# 组件重命名为 dateselect
buijs get 237 dateselect
效果预览
注意:
- 同一个工程可以多次创建模板;
模板名以
main-
开头 会覆盖 main 模块, 例如: 模板名main-tab
预览地址index.html
模板名以page-
开头 会新增页面, 例如: 模板名page-login
预览地址index.html#pages/login/login
; main-
开头的模板会覆盖main页面,page-
开头的模板是新增页面;- 同一个工程只能创建一个平台, 多次创建会相互覆盖;
- id 为远程模板,非本地模板,需要以官网的组件或模板为主;
创建指定平台工程 ( dcloud 为平台名称 )
可以先查看有什么平台选择 buijs list-platform
注意:
- 目前已经支持以下打包平台 cordova,bingotouch,dcloud,apicloud,appcan,微信 等;
- 不同平台对应的文件会有些许不同, 绑定原生后退的方法也不同, 不指定平台时, 默认是webapp平台, 可以在微信及webkit浏览器内核预览.
以下内容都是以进入 demo 工程示例.
# 创建Dcloud平台的应用
$ buijs create -p dcloud
创建dcloud平台下的某个模板工程
$ buijs create -t sidebar -p dcloud
创建sass编译工程
$ buijs create -p sass
创建less编译工程
$ buijs create -p less
创建指定版本工程
可以先查看有什么版本 buijs list
buijs create v1.0
更新工程为最新bui版本
buijs update
更新工程为最新bui版本及平台
buijs update -p bingotouch
创建多页工程
buijs create -p mpa
更新工程为最新npm开发模式 node10以上使用以下方式更新
buijs update -d
也可以指定更新对应的node版本
buijs update -d node8
buijs update -d node8-sass
buijs update -d node10
buijs update -d node10-sass
创建新模块
模块的访问路径: 默认: index.html#pages/article/index
buijs create -m article
打开文档
# 打开入门文档
buijs opendoc
# 打开组件文档
buijs opendoc component
打开API文档
buijs openapi
七、目录说明:
单页应用包文件夹说明:
| 路径 | 描述 | | :----------------------- | :-------------------------------------- | | gulpfile.js | 入口文件 | | package.json | npm依赖配置文件 | | app.json | 入口文件 | | dist/ | 编译打包最终要部署的目录 | | src/index.html | 入口文件 | | src/index.js | 入口的脚本 | | src/css/bui.css | BUI库的样式文件 | | src/css/style.css | 当前应用的样式文件 | | src/font/ | 字体图标目录 | | src/images/ | 应用图片目录 | | src/scss/ | 样式源文件,样式最好放这里可以分模块管理 | | src/js/zepto.js | bui的依赖库 | | src/js/bui.js | BUI交互控件库 | | src/pages/ | 模块目录 | | src/pages/main | 默认 main 模块 | | src/pages/main/main.html | 默认 main 模块模板 | | src/pages/main/main.js | 默认 main 模块定义脚本 |
八、多个bui工程共享node_modules
模块目录
现在每次创建一个工程以后, 每次都需要执行 npm install
特别的繁琐, 通过以下步骤, 可以创建一个bui的相关工程共享 node_modules
- 升级buijs 0.5.3
- 创建bui工程目录, 作为所有工程目录
buijs create bui-projects
, 删除 src目录,app.json ,只保留package.json, gulpfile.js
cd bui-projects
进入目录npm install
安装依赖模块buijs create project1
创建带工程名的工程npm run dev-project1
运行服务预览 或者npm run build-project1
编译打包
# 创建 bui-projects 文件夹作为公共的bui应用目录
buijs create bui-projects
# 进入这个目录
cd bui-projects/
# 安装依赖
npm install
# 创建 project1 工程
buijs create project1
# 运行预览
npm run dev-project1
# 编译打包
npm run build-project1
project1/gulpfile.js, project1/package.json 这两个文件则不需要了
九、更改数据源
废弃
十、创建完整案例参考
废弃 ,更多功能将通过百搭可视化构建工具实现
# 创建163案例
buijs create -t case-163
十一、创建皮肤
- 创建主色皮肤
npm run dev
主色皮肤运行以后就会覆盖掉 原本的色系
# 先让你的文件支持sass
buijs create -p sass
# 创建一个红色皮肤, 在__variables.scss 文件里面通过 $main-color 修改为其它主色调, 会把头部等样式替换
buijs create -p skin
- 创建深夜模式皮肤
深色皮肤跟主色皮肤的区别在于很多配色是相反的, 一般不需要修改, 运行以后,会在 css/bui-skindeep.css 生成样式文件,需要在 index.html 主动引入或者通过脚本控制切换.
# 先让你的文件支持sass
buijs create -p sass
# 创建一个深色皮肤
buijs create -p skindeep
十二、疑难问题
- 保存代码不会自动更新?
答:工程有使用
npm run dev
以后,会默认支持热更新, 工程只能在英文名路径下.
- 找不到全局变量?
答: 在node10以上创建的新工程, 默认对es6编译更加友好, 但当执行了
npm run build
命令以后, 这个编译把脚本变成了闭包, 工程原本的全局变量, 变成了局部变量, 公共脚本用var
声明的全局变量都无法找到. 有4种解决办法,
- 最简单的方法是使用 window.xxx 来替代公共方法的 var 声明.
- 一开始就使用 loader.define 定义这个模块, 然后在每个模块需要用的时候引入, 这样就不会有这个问题了.
- 把文件命名为
xxx.min.js
就会跳过编译. 但这样就要求里面不能有es6的写法, 因为打包以后对es6支持不好. - 1.6.2 新增了一个新的定义方式, 比较推荐. 4.1. common.js 使用这个方法构建全局方法
loader.global(function(global){
// global: 为上次执行的依赖
return {
test: function(){
console.log("test");
},
test2: function(){
console.log("test2");
}
}
})
4.2. 推荐: 局部调用
loader.define(function(require,export,module,global){
// 调用test方法
global.test();
})
4.3 全局调用:
loader.globals.test();