Skip to content

Latest commit

 

History

History
 
 

saturn-console-web

Starter project using webpack2 with ES6 and Vue

基于Webpack2和ES6/Vue,用于构建单页应用的Starter Project。

这个Project使用了:webpack2 + Babel + ESLint + Vue + webpack-dev-middleware + webpack-hot-middleware + express

这个Project的目的:使用当前业界流行的工具链,构建一个方便使用到已有项目/新项目的StarterProject

Getting started

环境要求

Node4.0以上

建议使用Node>=6 / NPM>=3版本, 可以使用nvm来切换不同Node版本

推荐使用Yarn

如何安装

  • npm:npm install or npm i
  • yarn: yarn install

进入开发模式

  • npm: npm run dev
  • yarn: yarn dev

命令完成后会自动打开浏览器进入http://localhost:8080

如果需要配置不同端口可以在/tasks/conf/app.conf.js的devPort里修改为其他端口

构建生产可用文件

  • npm: npm run build
  • yarn: yarn build

引入新的依赖

import devDependencies
  • npm: npm install --save-dev devDependency@version
  • yarn: yarn add --dev devDependency@version
import dependencies
  • npm: npm install --save dependency@version
  • yarn: yarn add dependency@version

锁定依赖版本

yarn会自动更新yarn.lock文件

但是npm需要手动更新npm-shrinkwrap.json,执行命令:npm shrinkwrap即可,如果有报错,可以执行npm prune再尝试npm shrinkwrap

屏蔽ESLint插件

由于ESLint默认在开发或者生产模式下都是打开的,设置/tasks/conf/app.conf.js里的eslintEnable: true,变量为false即可屏蔽ESLint插件

ESLint配置

当前使用了eslint-config-airbnb-base来配置ESLint规则

如果需要修改,那么首先增加新的config dependencyyarn add --dev eslint-config-***

再修改.eslintrc.js文件里的extends:'airbnb-base'这一行来调整为新的配置

也可以在.eslintrc.js文件里的rules下来新增自己的自定义规则

Babel配置

当前使用es2015和stage-2的babel preset.如果需要调整,那么设置.babelrc文件既可

如果不需要使用Babel插件来转换代码,设置/tasks/conf/app.conf.js里的babelEnable: true,变量为false即可屏蔽Babel插件

新增webpack loader

首先安装依赖npm install --save-dev package or yarn add --dev package

webpack配置放在/tasks/conf/webpack开头的配置文件里,当前这个版本有两个配置(dev/prod),所以新增loader的话需要在这两个文件配置里的rules下新增

File structure

建议目录结构如下

├── assets                        静态资源文件,会直接拷入到发布目录
├── src                           源码目录
│   ├── components                公共组件目录,pages里的UI一般由这里的组件和第三方组件拼装而成   
│   │   ├── DatePicker            公共DatePicker组件     
│   │   │   ├── DatePicker.js     DatePicker组件JS文件
│   │   │   ├── DatePicker.html   DatePicker组件模板
│   │   │   └── DatePicker.css    DatePicker组件样式
│   │   └── ...其他组件   
│   ├── pages                     应用业务界面目录,一般存放可路由到的业务UI,比如首页/仪表盘/订单详情等
│   │   ├── OrderMgr              订单管理页面     
│   │   │   ├── OrderMgr.js       订单管理页面JS文件
│   │   │   ├── OrderMgr.html     订单管理页面模板
│   │   │   └── OrderMgr.css      订单管理页面样式
│   │   └── ...其他pages  
│   ├── styles                    应用公共样式
│   └── index.js                  入口JS
├── tests                         测试相关目录
│   ├── unit                      单元测试目录
│   └── e2e                       e2e测试目录
├── mocks                         应用Mock API数据目录
├── tasks                         task相关文件存放目录
│   ├── conf                      task配置目录
│   │   ├── app.conf.js           一些全局设置和开关配置文件
│   │   ├── webpack.dev.conf.js   webpack开发模式配置文件
│   │   └── webpack.prod.conf.js  webpack生产模式配置文件
│   ├── utils                     task用到工具方法目录
│   ├── build.js                  yarn build执行文件,执行构建适合production的文件
│   └── dev.js                    yarn dev执行文件,进入开发模式方便开发
├── index.html	                  入口html
├── node_modules                  node_modules
├── package.json                  package.json
├── README.md                     README
├── npm-shrinkwrap.json           npm shirinkwrap文件
├── .babelrc                      babel配置
├── .eslintrc.js                  eslint配置
├── .eslintignore                 eslint忽略目录
└── yarn.lock                     yarn lock文件
  • 当前这个Demo并没有太多src下的内容,以上src目录里的内容只是建议。