dividing
v2.0.9
Published
a tool for multi-page project
Downloads
3
Maintainers
Readme
特点
- 多工程化:分包机制让每一个包都有独立的工程环境,让各个包共享同一个资源环境,可独立打包发布,降低发布成本。可独立调试,减少开发成本。
- 多环境支持:一套代码,多环境运行。通过配置环境变量实现同一套代码不同环境编译效果,加快版本迭代速度。
- 高拓展性:开放plugins、loader配置,可自行拓展脚本及加载器(默认支持vue、sass)
- 离线包功能:配合turbo移动开发平台实现字节级的差量更新
项目结构
webpack.config.js
项目配置文件,详情参见webpack配置
index.html
入口页面模板,可用于配置静态文件引入、meta信息、全局变量等公共属性
src/
业务逻辑开发目录(目录缩写默认为‘@’)
- src/assets/ 公共资源存放目录,业务代码可按需引入其中文件。(目录缩写默认为‘@a’)
- src/common/ 公共脚本,处理器存放目录。(src/commom/js默认缩写为‘@j’,src/common/scss默认缩写为‘@s’)
- src/components/ 公共组件存放目录。(目录默认缩写为‘@c’)
- src/modules/ 离线包存放目录。
- index.js 入口文件、用来配置vue初始化相关代码
//引入vue
import Vue from 'vue'
//定义初始化模板
const init = (App) => {
new Vue({
el: '#entry',
template: '<App />',
components: {App}
})
}
//输出初始化模板给各页面
export default init
缩写用法:
// img标签src用法
<img src="@a/demo.png" />
// css中给背景图赋值
.demo{
background-image: url('~@a/demo.png');
}
// 引入公共脚本
require('@j/bridge.js');
// 引入公共组件
import button from '@c/button.vue'
公共目录缩写配置参见webpack配置
src/modules/{离线包名}/index.js
配置离线包内生效的模块及页面
module.exports = {
wel: { // 生效的模块包名
come: {}, // 生效的页面名
}
}
src/modules/{离线包名}/{模块包名}/
页面文件夹存放目录
src/modules/{离线包名}/{模块包名}/{页面名}/
页面相关文件存放目录
- index.js 入口引用文件、将同目录下index.vue文件初始化
import init from '@/'
import app from './index.vue'
init(app)
- index.vue 页面文件
static/
公共静态库存放目录,目录内文件通过index.html模板文件静态引入
需要import转换可配置externals:
<!-- 因编译后入口目录层级加深,引用需要加上'../../' -->
<script src="../../static/vue.min.js"></script>
// webpack.config.js中配置
externals: {
'vue': 'window.Vue',
},
使用方式
安装依赖
$ npm run install
推荐使用cnpm进行安装
macos、linux请使用sudo命令获取管理员权限安装
本地调试
$ npm run dev
编译开始提示选择环境
本地构建
$ npm run build
编译开始提示选择环境
编译完成后会根据webpack.config.js中的配置运行sourcemap整理脚本,将各页面sourcemap文件放入指定文件夹
构建zip包
$ npm run zips
该命令将会把dist下所有目录打包成对应名称的zip文件
环境选择
$ 请输入运行的环境:
该命令会选择webpack.config.js中default.env中第一个环境为默认环境。
选中的环境中对应对象将会在所有页面文件中生效
选择完环境后提示选择离线包
离线包选择
$ 请输入需要打包的模块名,以空格分隔(不输入则全部打包):
src/modules/下的文件夹为离线包名称、输入各离线包名可以实现指定离线包打包功能
webpack配置
配置文件为根目录下webpack.config.js
dir
固定设置为_dirname
static
静态资源输出路径,默认static
- 固定名称:"'name'"
- 解析名称: "config.default.output + 'static'"
default
默认配置项,dev、build公共配置属性
- output - build输出目录,默认为dist
- chunks - 业务包内公共代码提取
- resolve - 解析,配置缩写及简写
- externals - 外部扩展,用于引入静态第三方库
- env - 环境变量配置,第一个环境为默认环境
- global - 全局变量配置
- packageID - 配置业务包id,run zips时根据ID打包为对应ID名的zips文件
- plugins - webpack插件列表,默认使用vue加载器、打包相关插件无需引入
- loader - webpack loader列表
dev
调试模式相关配置
- port - 实时调试模式监听端口号,默认8082
- host - 实时调试模式监听ip,默认0.0.0.0 等效于localhost
- devtool - sourcemap配置
- open - 实时调试模式开启后自动开启的页面
- proxy - 用于本地调试时访问跨域接口
build
编译模式相关配置
- devtool - sourcemap配置,默认source-map