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

vite項(xiàng)目添加eslint?prettier及husky方法實(shí)例

 更新時(shí)間:2022年07月04日 12:04:18   作者:傾墨  
這篇文章主要為大家介紹了vite項(xiàng)目添加eslint?prettier及實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

1. 初始化vite項(xiàng)目

npm init vite
? Project name: … vite-project // 項(xiàng)目名稱,默認(rèn) vite-project
? Select a framework: ? react  // 選擇框架
? Select a variant: ? react-ts // 選擇組合

2. 添加eslint

安裝

npm i -D eslint

初始化eslint配置

npx eslint --init
? How would you like to use ESLint? 
// To check syntax, find problems, and enforce code style
? What type of modules does your project use? 
// JavaScript modules (import/export)
? Which framework does your project use? 
// react
? Does your project use TypeScript? 
// Yes
? Where does your code run? 
// browser
? How would you like to define a style for your project? 
// Use a popular style guide
? Which style guide do you want to follow? 
// Airbnb
? What format do you want your config file to be in? 
// JavaScript

解決eslint報(bào)錯(cuò)

Missing semicolon.eslint: 末尾加上;即可

JSX not allowed in files with extension '.tsx': 在.eslintrc.json中添加rules設(shè)置

{
    // ...
    "react/jsx-filename-extension": [
        "error",
        {
            "extensions": [".js", ".jsx", ".tsx", ".ts"]
        }
    ]
};

{count} must be placed on a new line: 代碼換行即可;

Unable to resolve path to module './App': 在.eslintrc.json中添加rules設(shè)置

{
    // ...
    rules: {
         "import/no-unresolved": "off",
         "import/extensions": "off",
         "import/no-absolute-path": "off"
    },
};

'vite' should be listed in the project's dependencies, not devDependencies.:

.eslintrc.json中添加rules設(shè)置

{
    // ...
    "rules": {
        "import/no-extraneous-dependencies": [
            "error", 
            {"devDependencies": true}
        ]
        // ...
    }
};

3. 添加 prettier

安裝

npm i -D prettier eslint-config-prettier eslint-plugin-prettier

prettier: 核心模塊

eslint-config-prettier: 關(guān)閉所有不必要或可能跟prettier產(chǎn)生沖突的規(guī)則

eslint-plugin-prettier: 可以讓eslint使用prettier規(guī)則進(jìn)行檢查

配置

根目錄下.eslintrc.json文件中添加extends設(shè)置

{
    // ...
    "extends": [
        // ...
        "plugin:prettier/recommended",
    ],
}

根目錄下創(chuàng)建.prettierrc.json文件

{
  "trailingComma": "es5",
  "tabWidth": 2,
  "semi": true,
  "singleQuote": true
}

注意??:

修改.prettierrc.json文件后,需要重啟vscode才生效

如果配置后,配置不生效,嘗試以下設(shè)置:

4. 添加 husky和lint-staged

安裝

npm i -D lint-staged husky

配置

package.json中添加腳本

npm set-script prepare "husky install"

package.json文件的scripts中,就會(huì)自動(dòng)添加prepare;

2. 初始化husky,將 git hooks鉤子交由husky執(zhí)行

npm run prepare

會(huì)在根目錄創(chuàng)建.husky文件夾

3. 配置package.json

package.json文件如下:

{
  "env": {
    "browser": true,
    "node": true,
    "es2021": true
  },
  "extends": [
    "plugin:react/recommended",
    "airbnb",
    "plugin:prettier/recommended",
    "plugin:import/recommended"
  ],
  "parser": "@typescript-eslint/parser",
  "parserOptions": {
    "ecmaFeatures": {
      "jsx": true
    },
    "ecmaVersion": "latest",
    "sourceType": "module"
  },
  "plugins": ["react", "@typescript-eslint"],
  "rules": {
    "import/no-extraneous-dependencies": [
      "error", 
      {"devDependencies": true}
    ],
    "react/jsx-filename-extension": [
      "error",
      {
        "extensions": [".js", ".jsx", ".tsx", ".ts"]
      }
    ],
    "import/no-unresolved": "off",
    "import/extensions": "off",
    "import/no-absolute-path": "off"
  }
}

添加鉤子pre-commit

npx husky add .husky/pre-commit "npx lint-staged"

5. 配置commitlint

  • 作用:規(guī)范提交信息
  • 格式:git commit -m '類型: 描述性文字'
類型概念
build編譯相關(guān)的修改,例如發(fā)布版本、對(duì)項(xiàng)目構(gòu)建或者依賴的改動(dòng)
ci持續(xù)集成修改
docs文檔修改
feat新特性、新功能
fix修改bug
perf優(yōu)化相關(guān),比如提升性能、體驗(yàn)
refactor代碼重構(gòu)
revert回滾到上一個(gè)版本
style代碼格式修改, 注意不是 css 修改
test測(cè)試用例修改
chore其他修改,比如改變構(gòu)建流程、或者增加依賴庫(kù)、工具等
  • 安裝
npm i -D commitlint @commitlint/config-conventional
  • 配置

package.json中配置commitlint

{
    // ...
    "commitlint": {
        "extends": [
            "@commitlint/config-conventional"
        ]
    }
}
  • 添加鉤子
npx husky add .husky/commit-msg 'npx --no-install commitlint --edit "$1"'

git commit 就會(huì)觸發(fā)提交規(guī)范的校驗(yàn)啦;

以上就是vite項(xiàng)目添加eslint prettier及husky方法實(shí)例的詳細(xì)內(nèi)容,更多關(guān)于vite項(xiàng)目添加eslint prettier husky的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論