/webpack-seed

:roller_coaster: A Multi Page Application base on webpack and babel. webpack搭建多页面模板

Primary LanguageCSSMIT LicenseMIT

Webpack

Webpack babel License

前言

开箱即用的多页面脚手架, 基于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才能生效

编码规范

INSTRODUCTION

Api设置

API/README

项目结构

INSTRODUCTION

输出

Output source

  • dist/
  • ---html
  • ---image
  • ---media
  • ---css
  • ---js
  • ---lib
  • ---index.html

注意:如果有音视频等,会被打包在media目录

TODO

  • 添加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使用说明以及实现思路解析

更新日志

CHANGELOG

本项目目前接口(使用axios只能支持到IE10+), 项目本身支持IE9+

贡献代码

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.