wepack从0开始配置vue环境之二: 线上部署配置优化

wepack从0开始配置vue环境之一:基础配置
webpack之三集成vuex和vue-Router

  • 调整目录结构

新建/build存放webpack配置文件
build目录下新建文件:

  1. webpack.config.base.js(以下简称base) -> 基础配置文件
    复制/webpack.config.js文件到base, 删除isDev判断环境的代码, 删除所有的插件
  2. webpack.config.client.js(以下简称client) -> 客户端配置文件
    使用webpack-merge: cnpm i webpack-merge -D, 扩展base文件
    复制/webpack.config.js文件到client, 引入base, 删掉config, 引入webpack-merge, 声明一个config, 在两个不同的环境使用merge配置不同的参数,优化静态资源目录等
  3. 修改package.json的script命令
"build": "cross-env NODE_ENV=prodution npm run clean && webpack --config build/webpack.config.client.js",
    "dev": "cross-env NODE_ENV=development webpack-dev-server --config build/webpack.config.client.js",
  1. 调整业务代码存放文件的目录结构,每个部分单独创建文件夹,将src文件夹更名为client
  • vue-loader的配置

  1. 新建/build/vue-loader.config.js, module.exports 一个function, 为了判断环境
  2. vue-loader配置项:
    -- preserveWhitespace: false -> template里一行最后多余的空格会导致编译时出问题, 这个参数设置true可以忽略空格
    -- extractCSS: true -> 将.vue文件里的css单独打包成css文件
    -- cssModules{} -> css模块化, cssModules.localIdentName和camelCase: true(将css中用 '-' 连接的转化为驼峰)
    cssModules: {
      localIdentName: '[path]-[name]--[local]--[hash:base64:5]',
      camelCase: true
    } 
在.vue文件中使用
1.
<template>
  <div :class="a.header">我是header</div>
</template>
<style lang="stylus" scoped module="a">
.header
  color: #f00
</style>
2.
<template>
  <div :class="$style.header">我是header</div>
</template>
<style lang="stylus" scoped module>
.header
  color: #f00
</style>

css-loader也可以定义cssModules, 定义之后就必须以模块的方式引入css, 使用也类似rn里的css用 '.'访问

{
  loader: 'css-loader',
  options: {
    module: true,
    localIdentName: isDev ? '[path]-[name]--[local]--[hash:base64:5]' : '[name]-[hash:base64:5]'
  }
}

-- hotReload:false -> 禁用热重载, 这个选项是默认根据环境变量改变的, 不需单独设置
-- loaders: {'docs': docsLoader} -> .vue文件里自定义模块做自定义loader, 就是类似于<template>, <script>
-- preLoader: {js: zjdeloader} -> 先用这里的loader解析一遍在用webpack里的loader解析

  • eslint的配置

忽略eslint的方法, 忽略某行, 在对应行的末尾写上 // eslint-disable-line

  1. 安装模块:

eslint, eslint-config-standard, eslint-plugin-standard, eslint-plugin-promise, eslint-plugin-import, eslint-plugin-node, eslint-plugin-html
备注* 这些模板全部通过npm安装

  1. 新建/.eslintrc文件对eslint进行配置, 另eslint识别.vue里的template内容, 需要添加eslint-plugin-html
{
  "extends": "standard",
  "plugins": [
    "html"
  ]
}
  1. 在package.json的script中添加lint命令
// 检查代码格式错误
 "lint": "eslint --ext .js --ext .jsx --ext .vue client/" // `--ext`代表文件后缀, 最后的`client/`代表检查哪个目录下的文件
// 修正代码格式错误
"lint-fix": "eslint --fix --ext .js --ext .jsx --ext .vue client/"
  • 使用eslint实时检测代码格式

安装模块: eslint-loader babel-eslint -> webpack的项目要经过babel处理, 普通的eslint会有冲突需要在parse选项里使用一下

配置/eslintrc

{
  "extends": "standard",
  "plugins": ["html"],
  "parser": "babel-eslint",
  "rules": "off"    
  }
}

配置webpack.config.base.js, 添加eslint-loader

{
  test: /\.(vue|jsx|js)$/,
  loader: 'eslint-loader',
  exclude: /node_modules/,
  enforce: 'pre' // 在其他loader之前先解析, 不过就不会在进行其他loader解析了
}
  • 编辑器的.editorconfig 配置

说明: 统一编辑器配置的, 因为每个编辑器都有自己的默认配置

  1. 新建/.editorconfig
  2. 配置.editorconfig文件

科普:end_of_line(行结束符)3种不同的值,
lf -> linux crlf -> win cr -> mac
CRLF 是carriagereturnlinefeed的缩写。中文意思是回车换行。
LF是line feed的缩写,中文意思是换行。
CR是carriagereturn的缩写, 中文是回车

root = true
[*]
charset = utf-8 // 编码格式utf-8
end_of_line = lf // 因为线上环境是linux, 所有都设置成lf
indent_size = 2 // tab缩进格数
indent_style = space // 空格缩进
insert_final_newline = true // 保存时在最后插入一行空行
trim_trailing_whitespace = true // 清除一行结尾的空格
  1. 安装EditorConfig插件
  • git的precommit - 在commit之前进行eslint检查, 不通过不会提交

安装模块: husky -> git hook, 在安装之前一定要有.git目录, 安装之后会自动在.git里生成hook, 在commit之前执行 precommit命令

  1. 安装husky
  2. 在package.json的script里添加precommit命令
"precommit": "npm run lint-fix"
  1. git commit -m "xx", commit之后会先执行precommit里的命令, 报错就不会提交
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容