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

vite項(xiàng)目如何從0開(kāi)始配置eslint

 更新時(shí)間:2024年03月09日 09:10:46   作者:sqwu  
這篇文章主要介紹了vite項(xiàng)目如何從0開(kāi)始配置eslint問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vite創(chuàng)建的項(xiàng)目默認(rèn)沒(méi)有eslint,下面開(kāi)始從0開(kāi)始配置。

安裝eslint

npm install eslint --save-dev

初始化

npx eslint --init

// 選擇配置
√ How would you like to use ESLint? · problems    
√ What type of modules does your project use? · esm
√ Which framework does your project use? · vue
√ Does your project use TypeScript? · No / Yes
√ Where does your code run? · browser
√ What format do you want your config file to be in? · JavaScript
The config that you've selected requires the following dependencies:

eslint-plugin-vue@latest @typescript-eslint/eslint-plugin@latest @typescript-eslint/parser@latest
√ Would you like to install them now with npm? · No / Yes

解決Parsing error: ‘>’ expected

問(wèn)題:

vue文件的<script setup lang="ts">行出現(xiàn)報(bào)錯(cuò)Parsing error: '>' expected<br />

解決:

.eslintrc.js添加一行```“parser”:“vue-eslint-parser”,

module.exports = {
    "env": {
        "browser": true,
        "es2021": true
    },
    "parser": "vue-eslint-parser",
    "extends": [
        "eslint:recommended",
        "plugin:vue/essential",
        "plugin:@typescript-eslint/recommended"
    ],
    "parserOptions": {
        "ecmaVersion": "latest",
        "parser": "@typescript-eslint/parser",
        "sourceType": "module"
    },
    "plugins": [
        "vue",
        "@typescript-eslint"
    ],
    "rules": {
    }
}

解決The template root requires exactly one element

問(wèn)題:

一個(gè)模板只允許存在一個(gè)根節(jié)點(diǎn),這是vue2的校驗(yàn)規(guī)則,vue3是允許存在多個(gè)根節(jié)點(diǎn)的

解決:

1. 第一種是vetur配置調(diào)整,vscode設(shè)置搜索eslint,將框中的勾選去掉,不要選

2. 第二種是.eslintrc.js的配置調(diào)整,將extends中的plugin:vue/essential改為plugin:vue/vue3-essential

我i這邊是通過(guò)第二種方案解決的!

解決’defineProps’ is not defined

在.eslintrc.js的env下面添加'vue/setup-compiler-macros':true

rules配置

解決了上面的問(wèn)題之后,就可以根據(jù)官方文檔添加rules配置了,主要是根據(jù)公司或者個(gè)人開(kāi)發(fā)習(xí)慣定制規(guī)則。

// eslint-disable-next-line no-undef
module.exports = {
  'env': {
    'browser': true,
    'es2021': true,
    'vue/setup-compiler-macros': true
  },
  'parser': 'vue-eslint-parser',
  'extends': [
    'eslint:recommended',
    'plugin:vue/vue3-essential',
    'plugin:@typescript-eslint/recommended'
  ],
  'parserOptions': {
    'ecmaVersion': 'latest',
    'parser': '@typescript-eslint/parser',
    'sourceType': 'module'
  },
  'plugins': [
    'vue',
    '@typescript-eslint'
  ],
  // rules配置文檔http://eslint.cn/docs/rules/
  'rules': {
    // --以下是Possible Errors JS代碼中的邏輯錯(cuò)誤相關(guān)
    'no-extra-parens': 'error', // 禁止不必要的括號(hào)
    // "no-console": "error" // 不允許打印console.log
    'no-template-curly-in-string': 'error', // 禁止在常規(guī)字符串中出現(xiàn)模板字符串語(yǔ)法${xxx}
    // --以下是Best Practices 最佳實(shí)踐
    'default-case': 'error', // 強(qiáng)制switch要有default分支
    'dot-location': ['error', 'property'], // 要求對(duì)象的點(diǎn)要跟屬性同一行
    'eqeqeq': 'error', // 要求使用 === 和 !==
    'no-else-return': 'error', // 禁止在else前有return,return和else不能同時(shí)存在
    'no-empty-function': 'error', // 禁止出現(xiàn)空函數(shù),有意而為之的可以在函數(shù)內(nèi)部加條注釋
    'no-multi-spaces': 'error', // 禁止出現(xiàn)多個(gè)空格,如===前后可以有一個(gè)空格,但是不能有多個(gè)空格
    'no-multi-str': 'error', // 禁止出現(xiàn)多行字符串,可以使用模板字符串換行
    'no-self-compare': 'error', // 禁止自身比較
    'no-unmodified-loop-condition': 'error', // 禁止一成不變的循環(huán)條件,如while條件,防止死循環(huán)
    'no-useless-concat': 'error', // 禁止沒(méi)有必要的字符串拼接,如'a'+'b'應(yīng)該寫(xiě)成'ab'
    'require-await': 'error', // 禁止使用不帶await的async表達(dá)式
    // --以下是Stylistic Issues 主觀(guān)的代碼風(fēng)格
    'array-element-newline': ['error', 'consistent'], // 數(shù)組元素要一致的換行或者不換行
    'block-spacing': 'error', // 強(qiáng)制函數(shù)/循環(huán)等塊級(jí)作用域中的花括號(hào)內(nèi)前后有一個(gè)空格(對(duì)象除外)
    'brace-style': ['error', '1tbs', { 'allowSingleLine': true }], // if/elseif/else左花括號(hào)要跟if..同行,右花括號(hào)要換行;或者全部同一行
    'comma-dangle': ['error', 'only-multiline'], // 允許在對(duì)象或數(shù)組的最后一項(xiàng)(不與結(jié)束括號(hào)同行)加個(gè)逗號(hào)
    'comma-spacing': 'error', // 要求在逗號(hào)后面加個(gè)空格,禁止在逗號(hào)前面加一個(gè)空格
    'comma-style': 'error', // 要求逗號(hào)放在數(shù)組元素、對(duì)象屬性或變量聲明之后,且在同一行
    'computed-property-spacing': 'error', // 禁止在計(jì)算屬性中出現(xiàn)空格,如obj[ 'a' ]是錯(cuò)的,obj['a']是對(duì)的
    'eol-last': 'error', // 強(qiáng)制文件的末尾有一個(gè)空行
    'func-call-spacing': 'error', // 禁止函數(shù)名和括號(hào)之間有個(gè)空格
    'function-paren-newline': 'error', // 強(qiáng)制函數(shù)括號(hào)內(nèi)的參數(shù)一致?lián)Q行或一致不換行
    'implicit-arrow-linebreak': 'error', // 禁止箭頭函數(shù)的隱式返回 在箭頭函數(shù)體之前出現(xiàn)換行
    'indent': ['error', 2], // 使用一致的縮進(jìn),2個(gè)空格
    'jsx-quotes': 'error', // 強(qiáng)制在jsx中使用雙引號(hào)
    'key-spacing': 'error', // 強(qiáng)制對(duì)象鍵值冒號(hào)后面有一個(gè)空格
    'lines-around-comment': 'error', // 要求在塊級(jí)注釋/**/之前有一個(gè)空行
    'multiline-comment-style': 'error', // 多行注釋同一個(gè)風(fēng)格,每一行前面都要有*
    'new-cap': 'error', // 要求構(gòu)造函數(shù)首字母大寫(xiě)
    'newline-per-chained-call': ['error', { 'ignoreChainWithDepth': 2 }], // 鏈?zhǔn)秸{(diào)用長(zhǎng)度超過(guò)2時(shí),強(qiáng)制要求換行
    'no-lonely-if': 'error', // 禁止else中出現(xiàn)單獨(dú)的if
    'no-multiple-empty-lines': 'error', // 限制最多出現(xiàn)兩個(gè)空行
    'no-trailing-spaces': 'error', // 禁止在空行使用空白字符
    'no-unneeded-ternary': 'error', // 禁止多余的三元表達(dá)式,如a === 1 ? true : false應(yīng)縮寫(xiě)為a === 1
    'no-whitespace-before-property': 'error', // 禁止屬性前有空白,如console. log(obj['a']),log前面的空白有問(wèn)題
    'nonblock-statement-body-position': 'error', // 強(qiáng)制單行語(yǔ)句不換行
    'object-curly-newline': ['error', { 'multiline': true }], // 對(duì)象數(shù)屬性要有一致的換行,都換行或都不換行
    'object-curly-spacing': ['error', 'always'], // 強(qiáng)制對(duì)象/解構(gòu)賦值/import等花括號(hào)前后有空格
    'object-property-newline': ['error', { 'allowAllPropertiesOnSameLine': true }], // 強(qiáng)制對(duì)象的屬性在同一行或全換行
    'one-var-declaration-per-line': 'error', // 強(qiáng)制變量初始化語(yǔ)句換行
    'operator-assignment': 'error', // 盡可能的簡(jiǎn)化賦值操作,如x=x+1 應(yīng)簡(jiǎn)化為x+=1
    'quotes': ['error', 'single'], // 要求字符串盡可能的使用單引號(hào)
    'semi': ['error', 'never'], // 不要分號(hào)
    'semi-spacing': 'error', // 強(qiáng)制分號(hào)后面有空格,如for (let i=0; i<20; i++)
    'semi-style': 'error', // 強(qiáng)制分號(hào)出現(xiàn)在句末
    'space-before-blocks': 'error', // 強(qiáng)制塊(for循環(huán)/if/函數(shù)等)前面有一個(gè)空格,如for(...){}是錯(cuò)的,花括號(hào)前面要空格:for(...) {}
    'space-infix-ops': 'error', // 強(qiáng)制操作符(+-/*)前后有一個(gè)空格
    'spaced-comment': 'error', // 強(qiáng)制注釋?zhuān)?/或/*)后面要有一個(gè)空格
    // --以下是ECMAScript 6 ES6相關(guān)的
    'arrow-body-style': 'error', // 當(dāng)前頭函數(shù)體的花括號(hào)可以省略時(shí),不允許出現(xiàn)花括號(hào)
    'arrow-parens': ['error', 'as-needed'], // 箭頭函數(shù)參數(shù)只有一個(gè)時(shí),不允許寫(xiě)圓括號(hào)
    'arrow-spacing': 'error', // 要求箭頭函數(shù)的=>前后有空格
    'no-confusing-arrow': 'error', // 禁止在可能與比較操作符混淆的地方使用箭頭函數(shù)
    'no-duplicate-imports': 'error', // 禁止重復(fù)導(dǎo)入
    'no-useless-computed-key': 'error', // 禁止不必要的計(jì)算屬性,如obj3={['a']: 1},其中['a']是不必要的,直接寫(xiě)'a'
    'no-var': 'error', // 要求使用let或const,而不是var
    'object-shorthand': 'error', // 要求對(duì)象字面量使用簡(jiǎn)寫(xiě)
    'prefer-const': 'error', // 要求使用const聲明不會(huì)被修改的變量
    'prefer-destructuring': ['error', {
      'array': false,
      'object': true
    }, { 'enforceForRenamedProperties': true }], // 要求優(yōu)先使用結(jié)構(gòu)賦值,enforceForRenamedProperties為true將規(guī)則應(yīng)用于重命名的變量
    'prefer-template': 'error', // 使用模板字符串,而不是字符串拼接
    'rest-spread-spacing': 'error', // 擴(kuò)展運(yùn)算符...和表達(dá)式之間不允許有空格,如... re1錯(cuò)誤,應(yīng)該是...re1
    'template-curly-spacing': 'error', // 禁止模板字符串${}內(nèi)前后有空格
  }
}

使用vscode快捷鍵一鍵格式化

??右鍵 -> 使用…格式化文檔 -> (最后一項(xiàng))配置默認(rèn)格式化程序 -> 選擇ESlint。 

之后開(kāi)發(fā)時(shí)有eslint報(bào)錯(cuò)時(shí),使用shift+alt+f格式化,可以解決大部分報(bào)錯(cuò),個(gè)別無(wú)法格式化的就手動(dòng)解決吧~

配置lint指令

在package.json的scripts添加指令"lint":"eslint src/**/*.{js,jsx,vue,ts,tsx} --fix",之后執(zhí)行npm run lint 也可以自動(dòng)修復(fù)eslint報(bào)錯(cuò)。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue3中ref和reactive的用法和解析(推薦)

    vue3中ref和reactive的用法和解析(推薦)

    這篇文章主要介紹了vue3的ref和reactive的用法和解析,開(kāi)始部分講解了ref,reactive的使用實(shí)例,如何進(jìn)行類(lèi)型的標(biāo)注,配合ts這么使用,接著講解了兩者的區(qū)別,分別需要注意的點(diǎn),還有ref的頂層自動(dòng)解包,需要的朋友可以參考下
    2023-03-03
  • vue自定義組件如何通過(guò)v-model指令控制組件的隱藏、顯示

    vue自定義組件如何通過(guò)v-model指令控制組件的隱藏、顯示

    這篇文章主要介紹了vue自定義組件如何通過(guò)v-model指令控制組件的隱藏、顯示,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue CLI中模式與環(huán)境變量的深入詳解

    Vue CLI中模式與環(huán)境變量的深入詳解

    模式是 Vue CLI 項(xiàng)目中一個(gè)重要的概念,下面這篇文章主要給大家介紹了關(guān)于Vue CLI中模式與環(huán)境變量的相關(guān)資料,需要的朋友可以參考下
    2021-05-05
  • vue的自定義指令傳參方式

    vue的自定義指令傳參方式

    這篇文章主要介紹了vue的自定義指令傳參方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue后臺(tái)返回格式為二進(jìn)制流進(jìn)行文件的下載方式

    vue后臺(tái)返回格式為二進(jìn)制流進(jìn)行文件的下載方式

    這篇文章主要介紹了vue后臺(tái)返回格式為二進(jìn)制流進(jìn)行文件的下載方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • vue3路由跳轉(zhuǎn)params傳參接收不到的解決辦法

    vue3路由跳轉(zhuǎn)params傳參接收不到的解決辦法

    這篇文章主要給大家介紹了關(guān)于vue3路由跳轉(zhuǎn)params傳參接收不到的解決辦法,Vue3是目前前端開(kāi)發(fā)中非常流行的框架之一,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • Vue.directive使用注意(小結(jié))

    Vue.directive使用注意(小結(jié))

    這篇文章主要介紹了Vue.directive使用注意(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • 基于Vue的文字跑馬燈組件(npm 組件包)

    基于Vue的文字跑馬燈組件(npm 組件包)

    這篇文章主要介紹了基于Vue的文字跑馬燈組件(npm 組件包),需要的朋友可以參考下
    2017-05-05
  • @vue/cli4.x版本的vue.config.js常用配置方式

    @vue/cli4.x版本的vue.config.js常用配置方式

    這篇文章主要介紹了@vue/cli4.x版本的vue.config.js常用配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue3.0 的 Composition API 的使用示例

    vue3.0 的 Composition API 的使用示例

    這篇文章主要介紹了vue3.0 的 Composition API 的使用示例,幫助大家更好的理解和學(xué)習(xí)vue,感興趣的朋友可以了解下
    2020-10-10

最新評(píng)論