代碼校驗可以保持代碼的統一性以及追蹤語法錯誤。.vue 文件可以通過使用?`eslint-plugin-html`插件來校驗代碼。你可以通過?`vue-cli`?來開始你的項目,`vue-cli`?默認會開啟代碼校驗功能。
### [](https://github.com/pablohpsilva/vuejs-component-style-guide/blob/master/README-CN.md#為什么-12)為什么?
* 保證所有的開發者使用同樣的編碼規范。
* 更早的感知到語法錯誤。
### [](https://github.com/pablohpsilva/vuejs-component-style-guide/blob/master/README-CN.md#怎么做-11)怎么做?
為了校驗工具能夠校驗?`*.vue`文件,你需要將代碼編寫在?`<script>`標簽中,并使[組件表達式簡單化](https://github.com/pablohpsilva/vuejs-component-style-guide/blob/master/README-CN.md#%E4%BF%9D%E6%8C%81%E7%BB%84%E4%BB%B6%E8%A1%A8%E8%BE%BE%E5%BC%8F%E7%AE%80%E5%8D%95%E5%8C%96),因為校驗工具無法理解行內表達式,配置校驗工具可以訪問全局變量?`vue`?和組件的?`props`。
#### [](https://github.com/pablohpsilva/vuejs-component-style-guide/blob/master/README-CN.md#eslint)ESLint
[ESLint](http://eslint.org/)?需要通過?[ESLint HTML 插件](https://github.com/BenoitZugmeyer/eslint-plugin-html#eslint-plugin-html)來抽取組件中的代碼。
通過?`.eslintrc`?文件來配置 ESlint,這樣 IDE 可以更好的理解校驗配置項:
```source-json
{
"extends": "eslint:recommended",
"plugins": ["html"],
"env": {
"browser": true
},
"globals": {
"opts": true,
"vue": true
}
}
```
運行 ESLint
```source-shell
eslint src/**/*.vue
```
#### [](https://github.com/pablohpsilva/vuejs-component-style-guide/blob/master/README-CN.md#jshint)JSHint
[JSHint](http://jshint.com/)?可以解析 HTML(使用?`--extra-ext`命令參數)和抽取代碼(使用?`--extract=auto`命令參數)。
通過?`.jshintrc`?文件來配置 ESlint,這樣 IDE 可以更好的理解校驗配置項。
```source-json
{
"browser": true,
"predef": ["opts", "vue"]
}
```
運行 JSHint
```source-shell
jshint --config modules/.jshintrc --extra-ext=html --extract=auto modules/
```
注:JSHint 不接受?`vue`?擴展名的文件,只支持?`html`。
- Vue開發規范
- 基于模塊開發
- 組件
- 組件命名規則
- 基礎組件名
- 單例組件名
- 緊密耦合的組件名
- 組件名中的單詞順序
- 組件文件夾命名規則
- method方法
- methods方法命名規則
- 組件結構化
- 組件事件命名規則
- v-for與v-if
- 為 v-for 設置鍵值
- 避免 v-if 和 v-for 用在一起
- Prop
- Prop命名規則
- Prop定義
- 避免 this.$parent
- 謹慎使用 this.$refs
- 隱性的父子組件通信
- 元素
- 元素特性的順序
- 多個特性的元素擺放規則
- 單文件組件的頂級元素的順序
- 簡化代碼
- 模板中簡單的表達式
- 簡單的計算屬性
- 指令縮寫
- 文件引用路徑
- 其他注意
- 組件數據
- 將 this 賦值給 component 變量
- 對組件文件進行代碼校驗
- 盡可能使用 mixins
- 非 Flux 的全局狀態管理
- 只在需要時創建組件
- HTML開發規范
- HTML語法
- HTML5 doctype
- 語言屬性
- IE 兼容模式
- 字符編碼
- 引入 CSS 和 JavaScript 文件
- 實用為王
- 屬性順序
- 布爾(boolean)型屬性
- 減少標簽的數量
- JavaScript 生成的標簽
- CSS開發規范
- CSS語法
- 聲明順序
- 不要使用 @import
- 媒體查詢(Media query)的位置
- 帶前綴的屬性
- 單行規則聲明
- 簡寫形式的屬性聲明
- Less 和 Sass 中的嵌套
- Less 和 Sass 中的操作符
- 注釋
- class 命名
- 選擇器
- 代碼組織