开箱即用的多页面脚手架, 基于webpack4 babel7开发可复用的现代化网站, 解决非SPA应用, html复用, 模块化开发编译等问题.
如果感兴趣该项目, 请点个 star
及时关注项目更新, 请点个 watch
项目bug, 请提 issue
- 支持前后端分离开发
- 配置完整的打包方案
- 支持本地开发热更新
- EJS 模板编译
- Base64 图片,雪碧图
- 内置Sass开发环境
- Autoprefixer自动补全
- 集成代码风格校验Eslint
- 内置字体图标库500+, 开箱即用
- 支持ES6编写源码,编译生成生产代码
- 开发(生产)环境代码自动注入页面, 专注于开发
- 编译后的程序不依赖于外部的资源, 可自动替换线上资源地址
- 开箱即用的单元测试环境(当然了,测试用例还得您自己写)
- ...
注:本项目不依赖Jquery. lib.js可引入jquery,该文件配置可自动加载第三方脚本作为链接使用(script标签的形式引入), 如果需要,在src/common/lib/libs.js配置文件中打开注释即可
展示下页面呈现结果(页面资源加载逻辑),这可能就是我们想要的模块化吧:sparkles:
页面 | 公用样式 | 当前页面私有样式 | 底层核心库 | 页面公用类库 | 当前页面私有模块 |
---|---|---|---|---|---|
首页 | common.css | index.css | core.js | common.js | index.js |
列表页 | common.css | list.css | core.js | common.js | list.js |
详情页 | common.css | detail.css | core.js | common.js | detail.js |
购物车 | common.css | goods.css | core.js | common.js | goods.js |
登录页 | common.css | login.css | core.js | common.js | login.js |
下载使用
git clone https://github.com/BiYuqi/webpack-seed.git
cd webpack-seed
npm install
本地开发(dev)
npm run dev
打包(build)
- 默认情况下,该配置方案假设你的应用是被部署在一个域名的根路径上例如 https://www.my-app.com/
- 如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径
- 例如,如果你的应用被部署在 https://www.my-app.com/my-app/
- 则设置 webpack的output.publicPath 为 /my-app/
- 本项目由于需要临时部署在git-pages预览 所以改配置临时改为/webpack-seed/
- 普通打包(大部分) npm run build 默认 '/'
- 该命令具体请看package.json scripts命令配置
- 配置详情
- scripts命令配置
// 普通打包(大部分) npm run build publicPath默认 '/'
npm run build
// 打包时 npm run build:git 该命令会打包的路径会自动带上github项目地址/webpack-seed/
//(当发布环境不是服务器根路径,都可以采用该方案,只需更改路径名称即可,本项目二级路径为webpack-seed)
npm run build:git
依赖分析
// 利用webpack-bundle-analyzer 进行代码构建分析
npm run analyzer
测试
// karma mocha chai
npm run test
检测代码格式
npm run lint
格式化代码
npm run prettier
自动跑所有校验
// inclde lint prettier test
npm run ci
注意:本项目有提交代码前跑lint的功能,请看package.jsonhusky
字段配置
支持命令行创建页面
该命令支持创建页面四件套, 帮助快速构建页面, 无需重复coding README
npm run new
注:创建页面后需要重新执行
npm run dev
才能生效
- dist/
- ---html
- ---image
- ---media
- ---css
- ---js
- ---lib
- ---index.html
注意:如果有音视频等,会被打包在media目录
- 添加ejs模板,进行页面(首尾)复用, 页面功能模板渲染
- mini-css-extract-plugin 提取js内引入scss文件失败, 打包后依然在js文件(已解决)
- 首页页面模板未完成(单独处理打包)
- 添加第三方库以链接的方式引入
- 增加ESLint代码校验
- 增加两个文件夹,一个是fix IE兼容, 一个是引入的公用库,自动加载第三方库到页面,避免手动填写
- 增加网站未登录的模板(无header,footer)
- 添加多样化layout模板支持(示例layout/layoutAuth)
- 搭建单元测试环境(基于karma mocha chai)
- Use jest replace (基于karma mocha chai)
- 单独抽离配置文件webpack.seed.common.js
- 添加prettier自动格式化代码
- 提供一个cli工具生成项目
- 待完善测试用例编写
- 添加doc使用说明以及实现思路解析
本项目目前接口(使用axios只能支持到IE10+), 项目本身支持IE9+
- 先 Fork (https://github.com/BiYuqi/webpack-seed/fork)
- 创建分支 (git checkout -b your-idea)
- 提交更改 (git commit -am 'Fixed something')
- 推送更改 (git push origin your-idea)
- 创建一个 Pull Request
- If you got error about node-sass or sass-loader
Uncaught Error: Module build failed (from ./node_modules/sass-loader/lib/loader.js)
run:
npm rebuild node-sass --force
- IE
- Support IE9+ (not support flex, please note)
- Axios not support IE9, you can replace it with other ajax libraby.