Skip to content

Latest commit

 

History

History
123 lines (101 loc) · 4.46 KB

README.md

File metadata and controls

123 lines (101 loc) · 4.46 KB

MPA

针对公司业务使用 webpack4.x 和 babel7.x 整理的一个主要针对 H5 页面开发的脚手架,如果 PC 项目对 IE 兼容要求不高,也可以使用。

特点

  • 支持代码合并压缩、图片 base64、autoprefixer、代码版本控制;
  • 支持 es6、sass;
  • 支持热更新、tree-shaking 等;
  • 支持 eslint 代码校验、prettier 代码风格;
  • 支持业务代码和公共代码、webpack 运行时代码分离(最大化的利用浏览器缓存);
  • 支持开发、预发布、上线环境分离。

使用说明

# 开发
npm run dev # 或 npm start
# 访问方式
# http://localhost:8888/index.html
# http://localhost:8888/about.html
# http://localhost:8888/contact.html

# 预发布(用于上测试服)打包
npm run pre

# 上线打包
npm run build
# 上线打包可视化分析
npm run builda

# 代码格式校验
npm run lint

# 代码格式自动修复
npm run fix

注意:代码构建过程中 webpack 会注入三个全局变量(原则上只要使用 PRODUCTION 即可)

  • PRODUCTION: true 表示上线环境
  • DEVELOPMENT: true 表示开发环境
  • PREPRODUCTION: true 表示预发布环境

目录结构说明

.
├── .eslintrc.js  # eslint配置文件
├── .prettierrc.js  # prettier配置文件
├── build # webpack配置文件目录
│   ├── config.js
│   ├── webpack.common.js
│   ├── webpack.dev.js
│   └── webpack.prod.js
├── dist # 上线打包目录
├── pre # 预发布打包目录
├── static # 资源目录(有些公共资源不方便通过js引入,直接通过html引入的时候,可以放到这个目录(如 shareinstall),目录结构参考打包后目录结构)
└── src
    ├── api # 公共接口、日志处理目录(代码组织方式供参考)
    │   ├── config.js
    │   ├── data.js
    │   ├── index.js
    │   └── log.js
    ├── common  # 公共资源目录
    │   ├── css # 公共样式资源
    │   │   ├── _base.scss
    │   │   ├── _common.scss
    │   │   ├── _index.scss
    │   │   └── _mixin.scss
    │   └── js  # 公共js资源
    │       ├── SL-es.js
    │       ├── SLAPP-es.js
    │       └── responsive.js
    └── pages # 多页目录,每个页面一个目录,注意:每个页面目录下只允许有一个模板html和一个入口js,否则会影响打包。
        ├── about
        │   ├── about.html  # 模板html
        │   ├── about.js  # 入口js
        │   ├── about.scss  # 页面样式
        │   ├── img
        │   └── js  # 其他专用模块js
        ├── contact
        │   ├── contact.html  # 模板html
        │   ├── contact.js  # 入口js
        │   ├── contact.scss  # 页面样式
        │   ├── img
        │   └── js  # 其他专用模块js
        └── index
            ├── img
            ├── index.html  # 模板html
            ├── index.js  # 入口js
            ├── index.scss  # 页面样式
            └── js  # 其他专用模块js
                ├── math.js
                └── print.js

注意:每个页面目录下只允许有一个模板 html 和一个入口 js,否则会影响打包。

浏览器兼容

原则上是根据 package.jsonbrowserslist 配置来打包兼容,未详细测试验证,如发现有问题,请提 issue 或 pr

// package.json中配置
{
  "browserslist": [">= 1%", "last 2 version", "iOS >= 8", "Android >= 4.4"]
}
# 查看兼容结果列表
npx browserslist

贡献

如发现有 bug 或有更好的 idea,欢迎提 PR。

常见问题

  • 如发现打包后样式丢失,有可能是purifycss-webpack插件的 css Tree Shaking 功能导致误删了,解决方法,在 ./build/webpack.common.js:PurifyCssPlugin 配置中新增白名单(如排除包含 swiper 类名的样式:{whitelist: ['*swiper*']}),具体配置方法参考:purifycss-webpackpurifycss
  • 安卓 4.4.3 以下不支持 Promise 的兼容方法:window.Promise = require('es6-promise').Promise(请先安装依赖包npm install -S es6-promise);