vue單文件組件lint error自動fix與styleLint報錯自動fix詳解

這篇文章主要給大家介紹了關於vue單文件組件lint error自動fix與styleLint報錯自動fix的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨着小編來一起學習學習吧

問題描述

之前用Vue(多入口打包成多頁)的項目,要修改遷移並修改爲一個單頁應用,且使用Vue腳手架生成項目,要對js,vue,css文件的代碼做lint,在修改Webpack配置後第一次跑lint居然報了幾萬個Error,且是在eslint加了--fix選項的情況下,且錯誤大多集中在順序問題上也就是vue/order-in-components和order/properties-order的錯誤.以下是問題的解決方式及過程記錄.

stylelint中css屬性順序錯誤

.stylelint的配置

// .stylelint
{ 
 "processors": ["@mapbox/stylelint-processor-arbitrary-tags"],
 "plugins": [
 "stylelint-order",
 "stylelint-scss"
 ],
 "extends": ["css-properties-sorting"],
 "rules": {
 "order/order": [
  "custom-properties",
  "declarations"
 ],
 "color-no-invalid-hex": true,
 "unit-no-unknown": true,
 "property-no-unknown": true,
 "selector-pseudo-class-no-unknown": true,
 "selector-pseudo-element-no-unknown": true,
 "comment-no-empty": true,
 "number-leading-zero": "always",
 "number-no-trailing-zeros": true,
 "declaration-colon-space-after": "always",
 "declaration-colon-space-before": "never"
 }
}

在stylelint中加上--fix選項後,自動修復會把Vue文件中所有內容都移除掉,只剩css代碼

首先在stylelint的issue中發現了這樣的一個issue,基本現象一樣,問題是出現在配置中的processors項

移除配置中的processors後,發現stylelint檢測了各種文件(包括js/png等),執行lint的命令爲: stylelint **/*.{vue,css,scss} --fix

添加.stylelintignore文件,裏面忽略不用lint的文件後綴,最後完美解決css(包括scss/vue文件style標籤)中屬性順序錯誤自動修復問題

// .stylelintignore
*.js
*.png
*.eot
*.ttf
*.woff

eslint時vue文件中屬性順序錯誤

eslint-plugin-vue版本: 4.0.0

.eslintrc.js配置文件

module.exports = {
 root: true,
 parserOptions: {
 parser: 'babel-eslint'
 },
 env: {
 browser: true
 },
 extends: [
 'plugin:vue/recommended',
 'standard'
 ],
 plugins: ['vue'],
 rules: {
 'generator-star-spacing': 'off',
 'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off',
 'semi': 0,
 'indent': 0,
 'no-unused-vars': 0
 }
};

首先在eslint-plugin-vue的文檔中發現vue/order-in-componentsrule是支持自動修復的,然後去翻看了issue,發現這個issue中提到這個error不能自動修復的問題已經提了PR且merge了,於是果斷更新eslint-plugin-vue到最新版本(4.3.0)完美解決問題(ps:升級後又出現了個vue/attributes-order的錯誤,且文檔說不能自動修復,於是果斷ignore).

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對神馬文庫的支持。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章