<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>VSCode | ShareChiWai Notes</title><link>https://sharechiwai.com/category/vscode/</link><atom:link href="https://sharechiwai.com/category/vscode/index.xml" rel="self" type="application/rss+xml"/><description>VSCode</description><generator>HugoBlox Kit (https://hugoblox.com)</generator><language>en-us</language><lastBuildDate>Sun, 01 Mar 2026 00:00:00 +0800</lastBuildDate><image><url>https://sharechiwai.com/media/icon_hu_17828a82f3c79d3a.png</url><title>VSCode</title><link>https://sharechiwai.com/category/vscode/</link></image><item><title>VSCode Fix ESLint Issue on Save</title><link>https://sharechiwai.com/post/2026/2026-03-01-vscode-fix-eslint-issue-on-save/</link><pubDate>Sun, 01 Mar 2026 00:00:00 +0800</pubDate><guid>https://sharechiwai.com/post/2026/2026-03-01-vscode-fix-eslint-issue-on-save/</guid><description>&lt;p&gt;在日常開發中，我們經常需要使用 ESLint 來保持代碼質量和一致性。每次手動修復 ESLint 問題會很麻煩，但我們可以配置 VSCode 在保存文件時自動修復 ESLint 問題。&lt;/p&gt;
&lt;h2 id="配置-vscode-自動修復-eslint-問題"&gt;配置 VSCode 自動修復 ESLint 問題&lt;/h2&gt;
&lt;h3 id="1-安裝-eslint-擴展"&gt;1. 安裝 ESLint 擴展&lt;/h3&gt;
&lt;p&gt;首先，確保你已經安裝了 &lt;a href="https://marketplace.visualstudio.com/items?itemName=dbaeumer.vscode-eslint" target="_blank" rel="noopener"&gt;ESLint 擴展&lt;/a&gt;。&lt;/p&gt;
&lt;h3 id="2-配置-settingsjson"&gt;2. 配置 settings.json&lt;/h3&gt;
&lt;p&gt;打開 VSCode 的設定檔案（&lt;code&gt;settings.json&lt;/code&gt;），添加以下配置：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-json" data-lang="json"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;editor.codeActionsOnSave&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;source.fixAll.eslint&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;explicit&amp;#34;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;},&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;eslint.validate&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;javascript&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;javascriptreact&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;typescript&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;typescriptreact&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;vue&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;svelte&amp;#34;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;],&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;eslint.format.enable&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="kc"&gt;true&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h3 id="3-配置說明"&gt;3. 配置說明&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;&lt;code&gt;editor.codeActionsOnSave&lt;/code&gt;&lt;/strong&gt;: 當保存文件時，VSCode 會自動執行指定的 code actions。&lt;code&gt;source.fixAll.eslint&lt;/code&gt; 會讓 ESLint 自動修復所有可修復的問題。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;&lt;code&gt;eslint.validate&lt;/code&gt;&lt;/strong&gt;: 指定 ESLint 應該驗證哪些文件類型。根據你的項目需求添加或移除。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;&lt;code&gt;eslint.format.enable&lt;/code&gt;&lt;/strong&gt;: 啟用 ESLint 作為格式化程序。&lt;/p&gt;
&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id="4-項目級別配置"&gt;4. 項目級別配置&lt;/h3&gt;
&lt;p&gt;如果你只想在特定項目中啟用此功能，可以在項目根目錄創建 &lt;code&gt;.vscode/settings.json&lt;/code&gt; 檔案：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-json" data-lang="json"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;editor.codeActionsOnSave&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;source.fixAll.eslint&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;explicit&amp;#34;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;}&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;這樣設定只會對該項目生效，不會影響其他項目。&lt;/p&gt;
&lt;h2 id="注意事項"&gt;注意事項&lt;/h2&gt;
&lt;ol&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;自動修復的限制&lt;/strong&gt;: 不是所有 ESLint 問題都可以自動修復。有些問題（如缺失的 JSDoc）仍需手動處理。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;與 Prettier 的衝突&lt;/strong&gt;: 如果同時使用 Prettier，請確保 ESLint 和 Prettier 的規則不會衝突。可以使用 &lt;code&gt;eslint-config-prettier&lt;/code&gt; 來禁用 ESLint 中與 Prettier 衝突的規則。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;性能影響&lt;/strong&gt;: 對於大型項目，自動修復可能會稍微增加保存時間。如果感覺保存變慢，可以考慮只在特定文件類型上啟用。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;Git Hooks 整合&lt;/strong&gt;: 建議配合 &lt;code&gt;lint-staged&lt;/code&gt; 和 &lt;code&gt;husky&lt;/code&gt;，在提交前自動修復 ESLint 問題，確保代碼庫的一致性。&lt;/p&gt;
&lt;/li&gt;
&lt;/ol&gt;
&lt;h2 id="總結"&gt;總結&lt;/h2&gt;
&lt;p&gt;配置 VSCode 在保存時自動修復 ESLint 問題可以大大提高開發效率，減少手動修復的繁瑣工作。希望這個設定能幫助你保持代碼質量！&lt;/p&gt;
&lt;p&gt;Hope you find it useful!&lt;/p&gt;</description></item></channel></rss>