Vite4+Typescript+Vue3+Pinia 從零搭建(4) - 代碼規範

来源:https://www.cnblogs.com/weizwz/archive/2023/11/28/17862355.html
-Advertisement-
Play Games

項目代碼同步至碼雲 weiz-vue3-template 要求代碼規範,主要是為了提高多人協同和代碼維護效率,結合到此項目,具體工作就是為項目配置 eslint 和 prettier。 editorconfig 安裝 EditorConfig for VS Code 插件,根目錄下新建 .edito ...


項目代碼同步至碼雲 weiz-vue3-template
要求代碼規範,主要是為了提高多人協同和代碼維護效率,結合到此項目,具體工作就是為項目配置 eslintprettier

editorconfig

安裝 EditorConfig for VS Code 插件,根目錄下新建 .editorconfig 文件,增加以下配置

[*.{js,jsx,ts,tsx,vue}]
indent_style = space
indent_size = 2
end_of_line = crlf
trim_trailing_whitespace = true
insert_final_newline = true
max_line_length = 120

如果是非windows系統,end_of_line 設置為 cr

eslint

安裝可以參考官方教程 vue.js代碼規範
在這裡,我們建議使用另一種方式,安裝後,通過命令初始化。

1. 安裝

npm i eslint -D

2. 初始化

npm init @eslint/config

以下是操作實例:

PS D:\workspace\vue3\weiz-vue3-template> npm init @eslint/config
Need to install the following packages:
@eslint/[email protected]
Ok to proceed? (y)
# 輸入y開始安裝
? How would you like to use ESLint? ... # 如何使用eslint
  To check syntax only
  To check syntax and find problems
> To check syntax, find problems, and enforce code style # 檢查語法、發現問題並強制執行代碼風格
# 選擇第三項
? What type of modules does your project use? ... # 項目使用哪種類型的模塊
> JavaScript modules (import/export)
  CommonJS (require/exports)
  None of these
# 選擇第一項
? Which framework does your project use? ... # 使用哪種框架
  React
> Vue.js
  None of these
# 選擇 vue
? Does your project use TypeScript? » No / Yes # 項目里是否使用了ts
# 選擇yes
? Where does your code run? ...  (Press <space> to select, <a> to toggle all, <i> to invert selection)
# 代碼運行環境,輸入空格選擇,可以多選
√ Browser
√ Node
# 都選中後回車
  Use a popular style guide # 使用一種流行的風格指南
> Answer questions about your style # 自定義你的style
# 選擇第二項
? What format do you want your config file to be in? ... # 你的config配置文件類型
> JavaScript
  YAML
  JSON
# 建議選擇js
? What style of indentation do you use? ... # 使用什麼樣的縮進風格
  Tabs
> Spaces
# 建議空格
? What quotes do you use for strings? ... # 字元串使用單引號還是雙引號
  Double
> Single
# 單引號
? What line endings do you use? ... # 行尾格式
  Unix
> Windows
# Windows,如果是非windows系統,選擇 unix
? Do you require semicolons? » No / Yes # 是否需要分號
# No
@typescript-eslint/eslint-plugin@latest eslint-plugin-vue@latest @typescript-eslint/parser@latest eslint@latest
? Would you like to install them now? » No / Yes
# 檢查後列出以上項目,選擇yes安裝
? Which package manager do you want to use? ... # 使用哪種安裝方式
> npm
  yarn
  pnpm
# 選擇npm,然後等待安裝完成
...
added 138 packages, changed 1 package, and audited 184 packages in 50s

39 packages are looking for funding
  run `npm fund` for details

found 0 vulnerabilities
Successfully created .eslintrc.cjs file in D:\workspace\vue3\weiz-vue3-template

安裝完成,在根目錄下生成了 .eslintrc.cjs 文件,並自帶一些我們選擇的配置。

3. 簡易安裝

通過以上安裝我們發現,最終還是安裝了4個依賴,@typescript-eslint/eslint-plugin@latest eslint-plugin-vue@latest @typescript-eslint/parser@latest eslint@latest,如果我們熟悉的話,後續就可以直接安裝

npm i @typescript-eslint/eslint-plugin@latest eslint-plugin-vue@latest @typescript-eslint/parser@latest eslint@latest -D

然後在根目錄下新建 .eslintrc.cjs,然後把我們常用的配置複製進去即可。

4. .eslintrc.cjs 配置

以下附帶基礎配置:

module.exports = {
  env: {
    browser: true,
    es2021: true,
    node: true
  },
  extends: [
    'eslint:recommended',
    'plugin:@typescript-eslint/recommended',
    'plugin:vue/vue3-essential',
    'plugin:prettier/recommended' // 後續相容prettier
  ],
  overrides: [
    {
      env: {
        node: true
      },
      files: ['.eslintrc.{js,cjs}'],
      parserOptions: {
        sourceType: 'script'
      }
    }
  ],
  parserOptions: {
    ecmaVersion: 'latest',
    parser: '@typescript-eslint/parser',
    sourceType: 'module'
  },
  plugins: ['@typescript-eslint', 'vue'],
  rules: {
    indent: ['error', 2],
    'linebreak-style': ['error', 'windows'],
    quotes: ['error', 'single'],
    semi: ['error', 'never']
  }
}

5. .eslintignore

根目錄下新建 .eslintignore 文件,增加需要忽略類型檢查的文件和目錄

node_modules
dist
public
*.md
*.txt
.vscode
index.html

6. 增加命令

修改 package.json

"scripts": {
  "lint": "eslint --fix --ext .ts,.tsx,.vue,.js,.jsx --max-warnings 0"
}
運行 `npm run lint`,即可修複相關代碼問題

prettier

prettier 是為了方便格式化代碼,它的安裝比較簡單,後兩個依賴是為瞭解決和 eslint 的衝突

1. 安裝

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

2. .prettierrc

根目錄下新建 .prettierrc 文件,並增加以下配置

{
  "useTabs": false,
  "tabWidth": 2,
  "printWidth": 120,
  "singleQuote": true,
  "trailingComma": "none",
  "bracketSpacing": true,
  "semi": false,
  "endOfLine": "crlf"
}

如果是非windows,endOfLine 設置為 cr

3. .prettierignore

根目錄下新建 .prettierignore 文件,增加需要忽略格式化的文件和目錄

node_modules
dist
public
*.md
*.txt
.vscode
index.html

總結

做好以上配置後,可以運行 npm run lint 修複大部分代碼格式問題,或者右鍵使用 prettier 格式化代碼,將大大提高你的編碼效率。

文章作者:唯之為之

文章出處:https://www.cnblogs.com/weizwz/p/17862355.html

版權聲明:本博客所有文章除特別聲明外,均採用 「署名-非商業性使用-相同方式共用 4.0 國際」 許可協議,轉載請註明出處!

內容粗淺,如有錯誤,歡迎大佬批評指正


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本篇針對row_number() over(partition by order by) rn,並僅把rn列用於分類排序後篩選最大值的場景,分析了性能瓶頸的原因,並給出了兩種改進方案。 ...
  • HarmonyOS 開發入門(二) 日常逼逼叨 在HarmonyOS 開發入門(一)中我們描述了 HarmonyOS 開發的語言ArKTs以及Ts簡單的入門級語法操作,接下來我們進入第二部分HarmonyOS開發編輯器以及helloWorld項目創建,有任何說的不合理的地方,希望各位看官老爺批評指正 ...
  • HarmonyOS 開發入門(一) 日常逼逼叨 因為本人之前做過一些Android相關的程式開發,對移動端的開發興趣比較濃厚,近期也瞭解到了一些關於華為HarmonyOS 4.0 的事件熱點,結合黑馬相關教學視頻以及一些相關的技術博客,對HarmonyOS開發做一個知識總結,有任何說的不合理的地方, ...
  • 原文地址: Android app相容低版本Java環境 - Stars-One的雜貨小窩 起因是修複一個Bug遇到的問題,找到了一個可以讓app相容低版本java的方法 眾所周知,Android版本更新後,其內置的JRE環境也隨之更新了 假如我們在app中用到了JDK8的特有的屬性,而用戶的手機設 ...
  • 原來錯誤代碼 mounted() { .... this.map.addEventListener("click", function(e){//地圖單擊事件 var geocoder = new BMap.Geocoder(); var point = new BMap.Point(e.latln ...
  • typora-copy-images-to: media 數組 一、概念 對象中可以通過鍵值對存儲多個數據,且數據的類型是沒有限制的,所以通常會存儲一個商品的信息或一個人的信息: var obj = { goodsname:"手機", price:"5000", introduce:"手機很時尚,很 ...
  • 不要問自己需要什麼樣的人生,而要問自己想要成為什麼樣的人。 我們從前面的學習知道一個 React 組件不僅僅只包含 DOM 結構的,還應該樣式和 Javascript 邏輯的。這裡我們認識邏輯構造之事件處理。 1. React 事件處理 這裡列舉了在 React 中事件的幾種綁定處理方式: impo ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 仿貝殼地圖畫圈找房功能實現(高德地圖) 前言 在最近租房時,看到貝殼找房上線了一個地圖畫圈找房的功能,感覺很是新奇。接觸地圖開發也有很長一段時間了,以前大部分都是基於web pc端開發,所以一般遇到這種圈選,繪製多邊形圓形都是直接基於官方 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...