Vue項(xiàng)目中使用ellint和prettier

一般我們?cè)陧?xiàng)目中使用eslint和prettier來(lái)規(guī)范和約束我們的代碼

貼一份我的目錄結(jié)構(gòu)

image.png

安裝

我們?cè)谑褂胿ue-cli創(chuàng)建vue項(xiàng)目的時(shí)候會(huì)讓我們選擇校驗(yàn)方式蘸鲸,我們選擇ESLint + Prettier的方式丰歌,你也可以自己使用npm手動(dòng)安裝。

image.png

prettier

項(xiàng)目根目錄新建.prettierrc.json文件,貼一下我常用的配置,文件夾建完,之后我們ctrl+s保存的時(shí)候暮芭,就會(huì)按照這個(gè)規(guī)則格式化我們的代碼

{
    // tab縮進(jìn)大小,默認(rèn)為2
    "tabWidth": 4,
    // 使用tab縮進(jìn),默認(rèn)false
    "useTabs": false,
    // 使用分號(hào), 默認(rèn)true
    "semi": false,
    // 使用單引號(hào), 默認(rèn)false(在jsx中配置無(wú)效, 默認(rèn)都是雙引號(hào))
    "singleQuote": false,
    // 行尾逗號(hào),默認(rèn)none,可選 none|es5|all
    // es5 包括es5中的數(shù)組痒留、對(duì)象
    // all 包括函數(shù)對(duì)象等所有可選
    "TrailingCooma": "all",
    // 對(duì)象中的空格 默認(rèn)true
    // true: { foo: bar }
    // false: {foo: bar}
    "bracketSpacing": true,
    // JSX標(biāo)簽閉合位置 默認(rèn)false
    // false: <div
    //          className=""
    //          style={{}}
    //       >
    // true: <div
    //          className=""
    //          style={{}} >
    "jsxBracketSameLine": false,
    // 箭頭函數(shù)參數(shù)括號(hào) 默認(rèn)avoid 可選 avoid| always
    // avoid 能省略括號(hào)的時(shí)候就省略 例如x => x
    // always 總是有括號(hào)
    "arrowParens": "avoid"
}

eslint

1.項(xiàng)目根目錄新建.eslintrc.js文件

module.exports = {
  root: true,
  env: {
    node: true,
  },
  extends: [
    'plugin:vue/vue3-essential', //vue3核心的lint的規(guī)則
    'eslint:recommended', //eslint的建議規(guī)則
    '@vue/typescript/recommended',
    '@vue/prettier', //prettier建議的規(guī)則
    // '@vue/prettier/@typescript-eslint',
  ],
  parserOptions: {
    ecmaVersion: 2020,
  },
  rules: {
    semi: [1, 'never'],//always(總是) 或者 never(從來(lái)不)
    'no-console': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
    'no-debugger': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
    'prettier/prettier': [
      'warn',
      {
        trailingComma: 'es5',
      },
    ],
  },
  overrides: [
    {
      files: [
        '**/__tests__/*.{j,t}s?(x)',
        '**/tests/unit/**/*.spec.{j,t}s?(x)',
      ],
      env: {
        jest: true,
      },
    },
  ],
};

2.選項(xiàng)說(shuō)明

"root": true

默認(rèn)情況下,ESLint 會(huì)在所有父級(jí)目錄里尋找配置文件蠢沿,一直到根目錄伸头。如果發(fā)現(xiàn)配置文件中有 “root”: true,它就會(huì)停止在父級(jí)目錄中尋找舷蟀。


  extends: [
    'plugin:vue/vue3-essential', //vue3核心的lint的規(guī)則
    'eslint:recommended', //eslint的建議規(guī)則
    '@vue/typescript/recommended',
    '@vue/prettier', //prettier建議的規(guī)則
    '@vue/prettier/@typescript-eslint',
  ],

一個(gè)配置文件可以從基礎(chǔ)配置中繼承已啟用的規(guī)則恤磷。如上面哼,如果值為字符串?dāng)?shù)組則每個(gè)配置繼承它前面的配置。值為 “eslint:recommended” 的 extends 屬性啟用了eslint默認(rèn)的規(guī)則扫步,請(qǐng)參考:https://cn.eslint.org/docs/rules/


 rules: {
    semi: [2, 'always'],
    'no-console': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
    'no-debugger': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
    'prettier/prettier': [
      'warn',
      {
        trailingComma: 'es5',
      },
    ],
  },

ESLint 附帶有大量的規(guī)則魔策。你可以在rules選項(xiàng)中設(shè)置,設(shè)置的規(guī)則將覆蓋上面繼承的默認(rèn)規(guī)則河胎。要改變一個(gè)規(guī)則設(shè)置闯袒,你必須將規(guī)則 ID 設(shè)置為下列值之一:

  • “off” 或 0 - 關(guān)閉規(guī)則
  • “warn” 或 1 - 開(kāi)啟規(guī)則,使用警告級(jí)別的錯(cuò)誤:warn (不會(huì)導(dǎo)致程序退出)
  • “error” 或 2 - 開(kāi)啟規(guī)則游岳,使用錯(cuò)誤級(jí)別的錯(cuò)誤:error (當(dāng)被觸發(fā)的時(shí)候政敢,程序會(huì)退出)

3.看一個(gè)例子:
我上面在rules里面配置了semi: [1, 'never'],,意思就是禁止使用尾部分號(hào)胚迫,但是級(jí)別是警告喷户,那么我如果項(xiàng)目中尾部有分號(hào),我控制臺(tái)就會(huì)報(bào)警告信息

image.png

那如果我改成semi:[2,'never']的時(shí)候访锻,意思就是尾部禁止使用分號(hào)褪尝,但是級(jí)別變成錯(cuò)誤那么我如果項(xiàng)目中尾部有分號(hào),我程序就會(huì)報(bào)錯(cuò)期犬,終止執(zhí)行

image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末河哑,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子哭懈,更是在濱河造成了極大的恐慌灾馒,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,888評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件遣总,死亡現(xiàn)場(chǎng)離奇詭異睬罗,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)旭斥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門容达,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人垂券,你說(shuō)我怎么就攤上這事花盐。” “怎么了菇爪?”我有些...
    開(kāi)封第一講書人閱讀 168,386評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵算芯,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我凳宙,道長(zhǎng)熙揍,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 59,726評(píng)論 1 297
  • 正文 為了忘掉前任氏涩,我火速辦了婚禮届囚,結(jié)果婚禮上有梆,老公的妹妹穿的比我還像新娘。我一直安慰自己意系,他們只是感情好泥耀,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,729評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著蛔添,像睡著了一般痰催。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上作郭,一...
    開(kāi)封第一講書人閱讀 52,337評(píng)論 1 310
  • 那天陨囊,我揣著相機(jī)與錄音,去河邊找鬼夹攒。 笑死蜘醋,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的咏尝。 我是一名探鬼主播压语,決...
    沈念sama閱讀 40,902評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼编检!你這毒婦竟也來(lái)了胎食?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,807評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤允懂,失蹤者是張志新(化名)和其女友劉穎厕怜,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體蕾总,經(jīng)...
    沈念sama閱讀 46,349評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡粥航,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,439評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了生百。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片递雀。...
    茶點(diǎn)故事閱讀 40,567評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蚀浆,靈堂內(nèi)的尸體忽然破棺而出缀程,到底是詐尸還是另有隱情,我是刑警寧澤市俊,帶...
    沈念sama閱讀 36,242評(píng)論 5 350
  • 正文 年R本政府宣布杨凑,位于F島的核電站,受9級(jí)特大地震影響摆昧,放射性物質(zhì)發(fā)生泄漏撩满。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,933評(píng)論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望鹦牛。 院中可真熱鬧,春花似錦勇吊、人聲如沸曼追。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,420評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)礼殊。三九已至,卻和暖如春针史,著一層夾襖步出監(jiān)牢的瞬間晶伦,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,531評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工啄枕, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留婚陪,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,995評(píng)論 3 377
  • 正文 我出身青樓频祝,卻偏偏與公主長(zhǎng)得像泌参,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子常空,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,585評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容