欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解ESLint在Vue中的使用小結

 更新時間:2018年10月15日 14:28:49   作者:老哥二娃  
ESLint是一個QA工具,這篇文章主要介紹了詳解ESLint在Vue中的使用小結,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

ESLint是一個QA工具,用來避免低級錯誤和統(tǒng)一代碼的風格

ESLint的用途

1.審查代碼是否符合編碼規(guī)范和統(tǒng)一的代碼風格;

2.審查代碼是否存在語法錯誤;

中文網地址 http://eslint.cn/

使用VSCode編譯器在Vue項目中的使用

在初始化項目時選擇是否使用

ESLint管理代碼(選擇Y則默認開啟)

Use ESLint to lint your code? (Y/n)

默認使用的是此標準https://github.com/standard/standard/blob/master/docs/RULES-zhcn.md

以下是對.editorconfig、.eslintignore、.eslintrc.js 文件進行詳細解釋

.editorconfig文件(主要用于配置IDE)

規(guī)范縮進風格,縮進大小,tab長度以及字符集等,解決不同IDE的編碼范設置。EditorConfig 插件會去查找當前編輯文件的所在文件夾或其上級文件夾中是否有 .editorconfig 文件。如果有,則編輯器的行為會與 .editorconfig 文件中定義的一致,并且其優(yōu)先級高于編輯器自身的設置。

root = true
# 對所有文件有效 //[*js]只對js文件有效
[*]
#設置編碼格式
charset = utf-8
#縮進類型 可選space和tab
indent_style = space
#縮進數(shù)量可選整數(shù)值2 or 4,或者tab
indent_size = 2
#換行符的格式
end_of_line = lf
# 是否在文件的最后插入一個空行 可選true和false
insert_final_newline = true
# 是否刪除行尾的空格 可選擇true和false
trim_trailing_whitespace = true

.eslintignore文件(放置需要ESLint忽略的文件,只對.js文件有效)

/build/
/config/
/dist/
/src/utils/
/src/router/*.js

.eslintrc.js 文件(用來配置ESLint的檢查規(guī)則)

module.exports = {
  //此項是用來告訴eslint找當前配置文件不能往父級查找
  root: true, 
  //此項是用來指定eslint解析器的,解析器必須符合規(guī)則,babel-eslint解析器是對babel解析器的包裝使其與ESLint解析
  parser: 'babel-eslint',
  //此項是用來指定javaScript語言類型和風格,sourceType用來指定js導入的方式,默認是script,此處設置為module,指某塊導入方式
  parserOptions: {
    sourceType: 'module'
  },
  //此項指定環(huán)境的全局變量,下面的配置指定為瀏覽器環(huán)境
  env: {
    browser: true,
  },
  // https://github.com/feross/standard/blob/master/RULES.md#javascript-standard-style
  // 此項是用來配置標準的js風格,就是說寫代碼的時候要規(guī)范的寫,如果你使用vs-code我覺得應該可以避免出錯
  extends: 'standard',
  // required to lint *.vue files
  // 此項是用來提供插件的,插件名稱省略了eslint-plugin-,下面這個配置是用來規(guī)范html的
  plugins: [
    'html'
  ],
  // add your custom rules here
  // 下面這些rules是用來設置從插件來的規(guī)范代碼的規(guī)則,使用必須去掉前綴eslint-plugin-
  // 主要有如下的設置規(guī)則,可以設置字符串也可以設置數(shù)字,兩者效果一致
  // "off" -> 0 關閉規(guī)則
  // "warn" -> 1 開啟警告規(guī)則
  //"error" -> 2 開啟錯誤規(guī)則
  // 了解了上面這些,下面這些代碼相信也看的明白了
 rules: {
  // allow async-await
  'generator-star-spacing': 'off',
  // allow debugger during development
  'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off',
  // js語句結尾必須使用分號
  'semi': ['off', 'always'],
  // 三等號
  'eqeqeq': 0,
  // 強制在注釋中 // 或 /* 使用一致的空格
  'spaced-comment': 0,
  // 關鍵字后面使用一致的空格
  'keyword-spacing': 0,
  // 強制在 function的左括號之前使用一致的空格
  'space-before-function-paren': 0,
  // 引號類型
  "quotes": [0, "single"],
  // 禁止出現(xiàn)未使用過的變量
  // 'no-unused-vars': 0,
  // 要求或禁止末尾逗號
  'comma-dangle': 0
 }
}
  • “off” 或 0 - 關閉規(guī)則
  • “warn” 或 1 - 開啟規(guī)則
  • “error” 或 2 - 開啟規(guī)則

如何在老項目中加入ESlint

1. 在目錄中添加.editorconfig、.eslintrc.js、.eslintignore這三個文件

2. 在package.json的”devDependencies”中加入ESlint所需要的包

  "babel-eslint": "^7.1.1",
  "eslint": "^3.19.0",
  "eslint-config-standard": "^10.2.1",
  "eslint-friendly-formatter": "^3.0.0",
  "eslint-loader": "^1.7.1",
  "eslint-plugin-html": "^3.0.0",
  "eslint-plugin-import": "^2.7.0",
  "eslint-plugin-node": "^5.2.0",
  "eslint-plugin-promise": "^3.4.0",
  "eslint-plugin-standard": "^3.0.1",

3. 在bulid/webpack.base.conf.js文件中加入ESlint規(guī)則并生效

// 在module的rules中加入
 module: {
  rules: [
   {
    test: /\.(js|vue)$/,
    loader: 'eslint-loader',
    enforce: 'pre',
    include: [resolve('src'), resolve('test')],
    options: {
     formatter: require('eslint-friendly-formatter'),
     // 不符合Eslint規(guī)則時只警告(默認運行出錯)
     // emitWarning: !config.dev.showEslintErrorsInOverlay
    }
   },
  ]
 }

4. 重新bulid代碼運行,完美生效!!!!!!

推薦三個VSCode插件

  • ESLint (只支持高亮顯示js文件)
  • EditorConfig
  • Typings(代碼錯誤提示)

常見的報錯

文件末尾存在空行(eol-last)

缺少分號(‘semi': [‘error','always'])

關鍵字后面缺少空格

字符串沒有使用單引號('quotes': [1, 'single'])

縮進錯誤

沒有使用全等(eqeqeq)

導入組件卻沒有使用

new了一個對象卻沒有賦值給某個常量(可以在該實例前添加此代碼/eslint-disable no-new/忽略ESLint的檢查)

超過一行空白行(no-multiple-empty-lines)

注釋符 // 后面縮進錯誤(lines-around-comment)

VScode

用戶配置

{
  "workbench.startupEditor": "newUntitledFile",
  // 以下是按照ESLint格式化代碼
  "vetur.format.defaultFormatter.js": "vscode-typescript",
  "javascript.format.insertSpaceBeforeFunctionParenthesis": true,
  "editor.quickSuggestions": {
   "strings": true
  },
  "editor.tabSize": 2,
  "eslint.validate": [
   "javascript",
   "javascriptreact",
   "html",
   "vue",
   {
    "language": "html",
    "autoFix": true
   }
  ],
  // "files.autoSave": "onFocusChange",
  // "vetur.validation.template": false,
  // // 防止格式化代碼后單引號變雙引號
  // "prettier.singleQuote": true,
  "files.autoSave": "afterDelay",
  "files.autoSaveDelay": 1500,
  // "git.confirmSync": false
  // 配置是否從更新通道接收自動更新。更改后需要重啟。
  "update.channel": "none"
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 詳解vscode中vue代碼顏色插件

    詳解vscode中vue代碼顏色插件

    vscode的確是前端開發(fā)中很好的工具,安裝顏色插件,從視覺上是美的享受。這篇文章主要介紹了vscode中vue代碼顏色插件 ,需要的朋友可以參考下
    2018-10-10
  • 強烈推薦!Vue3.2中的setup語法糖

    強烈推薦!Vue3.2中的setup語法糖

    script?setup是vue3的新語法糖,并不是新增的功能模塊,只是簡化了以往的組合式API必須返回(return)的寫法,并且有更好的運行時性能,這篇文章主要給大家介紹了關于Vue3.2中setup語法糖的相關資料,需要的朋友可以參考下
    2021-12-12
  • Vue CLI 3搭建vue+vuex最全分析(推薦)

    Vue CLI 3搭建vue+vuex最全分析(推薦)

    這篇文章主要介紹了Vue CLI 3搭建vue+vuex最全分析(推薦),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • vue.js中created()與activated()的個人使用解讀

    vue.js中created()與activated()的個人使用解讀

    這篇文章主要介紹了vue.js中created()與activated()的個人使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • el-input輸入校驗不能為空格以及不能輸入全部為空的內容

    el-input輸入校驗不能為空格以及不能輸入全部為空的內容

    這篇文章主要給大家介紹了關于el-input輸入校驗不能為空格以及不能輸入全部為空的內容的相關資料,el-input驗證規(guī)則主要是為了確保輸入的內容符合特定的要求,需要的朋友可以參考下
    2023-10-10
  • 簡單談談Vue3中的ref和reactive

    簡單談談Vue3中的ref和reactive

    vue3中實現(xiàn)響應式數(shù)據(jù)的方法是就是使用ref和reactive,所謂響應式就是界面和數(shù)據(jù)同步,能實現(xiàn)實時更新,下面這篇文章主要給大家介紹了關于Vue3中ref和reactive的相關資料,需要的朋友可以參考下
    2023-04-04
  • Vue中$router.push()路由切換及如何傳參和獲取參數(shù)

    Vue中$router.push()路由切換及如何傳參和獲取參數(shù)

    這篇文章主要給大家介紹了關于Vue中$router.push()路由切換及如何傳參和獲取參數(shù)的相關資料,文中通過實例代碼介紹的非常詳細,對大家學習或者使用vue具有一定的參考學習價值,需要的朋友可以參考下
    2023-03-03
  • Vue終端取消vue、prettier警告warn問題

    Vue終端取消vue、prettier警告warn問題

    這篇文章主要介紹了Vue終端取消vue、prettier警告warn問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue之組件內監(jiān)控$store中定義變量的變化詳解

    vue之組件內監(jiān)控$store中定義變量的變化詳解

    今天小編就為大家分享一篇vue之組件內監(jiān)控$store中定義變量的變化詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Vue利用廣度優(yōu)先搜索實現(xiàn)watch

    Vue利用廣度優(yōu)先搜索實現(xiàn)watch

    這篇文章主要為大家學習介紹了Vue如何利用廣度優(yōu)先搜索實現(xiàn)watch(有意思),文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-08-08

最新評論