EP46 - 工具

更新於 發佈於 閱讀時間約 10 分鐘
Tooling應該是介紹許多實用的工具吧!
這應該對開發會非常有幫助,快來挖寶

在線嘗試 - Try it Online

你不需要在本機上安裝任何東西即可嘗試 Vue SFC - 有一些線上平台允許你直接在瀏覽器中進行嘗試:

同時,我們也推薦在報告錯誤時使用這些線上平台提供的復現例子。

專案鷹架 - Project Scaffolding​

Vite

Vite 是一個輕量且快速的建置工具,提供了對 Vue 單文件元件(SFC)的原生支持。它是由 Vue 的作者 Evan You 開發的!

要開始使用 Vite + Vue,只需執行以下命令:

$ npm create vue@latest

這條命令將安裝並執行 create-vue,官方的 Vue 專案鷹架工具。

要了解更多關於 Vite 的資訊,請查看 Vite 文檔

要在 Vite 專案中配置 Vue 特定的行為,例如將選項傳遞給 Vue 編譯器,請參考 @vitejs/plugin-vue 的文檔。上述提到的線上平台也支持將文件下載為 Vite 專案。

Vue CLI

Vue CLI 是官方基於 webpack 的工具鏈。現在它處於維護模式,我們建議新專案使用 Vite,除非你依賴於特定的 webpack 功能。在大多數情況下,Vite 將提供更優越的開發體驗。

有關從 Vue CLI 遷移到 Vite 的信息,請參考:

瀏覽器內模板編譯的注意事項

在沒有建置步驟的情況下使用 Vue 時,元件模板要麼直接寫在頁面的 HTML 中,要麼作為內嵌的 JavaScript 字串。在這種情況下,Vue 需要將模板編譯器發送到瀏覽器,以便進行即時模板編譯。另一方面,如果我們使用建置步驟預編譯模板,則不需要編譯器。為了減少客戶端捆綁包的大小,Vue 提供了不同的「版本」,針對不同的用例進行優化。

  • vue.runtime.* 開頭的建置文件是僅運行時的版本:它們不包括編譯器。使用這些版本時,所有模板必須通過建置步驟進行預編譯。
  • 不包含 .runtime 的建置文件是完整版本:它們包括編譯器並支持在瀏覽器中直接編譯模板。然而,它們將增加約 14KB 的負載。

我們的默認工具設置使用僅運行時的版本,因為 SFC 中的所有模板都是預編譯的。如果因某種原因,即使在有建置步驟的情況下,你仍需要在瀏覽器中編譯模板,可以通過配置建置工具將 vue 別名設置為 vue/dist/vue.esm-bundler.js 來實現。

如果你在尋找無需建置步驟的輕量替代方案,可以查看 petite-vue

Q:為什麼要遷移?

  1. 性能提升: Vite 透過即時服務器啟動和快速熱模組替換(HMR)提供更快的開發體驗。這使得開發者在修改代碼時能立即看到變更,而不需重新載入整個頁面。
  2. 簡化的配置: Vite 的配置通常比 Vue CLI 更簡單,並且預設情況下已經針對現代瀏覽器進行優化。這減少了繁瑣的設定時間。
  3. 現代化的工具: Vite 使用 ES 模組作為內部依賴,這使得開發環境更符合現代前端開發的標準,並更好地支持未來的技術演進。
  4. 更好的支援: Vite 獲得了更多社群和生態系統的支援,許多新特性和最佳實踐也更快地集成進 Vite。
  5. 持續維護: Vue CLI 現在處於維護模式,未來不會有重大更新。選擇 Vite 可以確保你在長期內能夠獲得最新的功能和修復。

IDE 支援 - IDE Support

建議的 IDE 設定是 VS Code 加上 Vue - Official 擴展(以前稱為 Volar)。該擴展提供語法高亮、TypeScript 支援以及模板表達式和組件屬性的智能提示功能。

提示: Vue - Official 取代了我們之前為 Vue 2 提供的官方 VS Code 擴展 Vetur。如果你目前在 Vue 3 專案中安裝了 Vetur,請務必在 Vue 3 專案中禁用它。

WebStorm 也提供了對 Vue SFC 的優秀內建支援。

其他支援語言服務協議(LSP)的 IDE 也可以透過 LSP 利用 Volar 的核心功能:

瀏覽器開發工具 - Browser Devtools​

Vue 瀏覽器開發工具擴展允許你探索 Vue 應用的組件樹,檢查單個組件的狀態,追蹤狀態管理事件,並分析性能。

raw-image

TypeScript

主文章:使用 Vue 與 TypeScript

Vue - 官方擴展提供對使用 <script lang="ts"> 區塊的 SFC 進行類型檢查,包括模板表達式和跨組件的屬性驗證。

使用 vue-tsc 可以從命令行執行相同的類型檢查,或生成 SFC 的 d.ts 文件。

測試 - Testing

主文章:測試指南

推薦使用 Cypress 進行端到端(E2E)測試。它也可以通過 Cypress 組件測試運行器用於 Vue SFC 的組件測試。

Vitest 是由 Vue/Vite 團隊成員創建的測試運行器,專注於速度。它專為基於 Vite 的應用設計,以提供相同的單元/組件測試即時反饋循環。

Jest 可以通過 vite-jest 與 Vite 一起使用。然而,這僅在你需要將現有的基於 Jest 的測試套件遷移到基於 Vite 的設置時才建議使用,因為 Vitest 提供相似的功能,並具有更高效的整合。

偵測錯誤 - Linting

Vue 團隊維護 eslint-plugin-vue,這是一個支持 SFC 特定 linting 規則的 ESLint 插件。

之前使用 Vue CLI 的用戶可能習慣通過 webpack loaders 配置 linting 工具。然而,當使用基於 Vite 的建置設置時,我們的一般建議是:

  1. npm install -D eslint eslint-plugin-vue

然後遵循 eslint-plugin-vue配置指南

  1. 設置 ESLint IDE 擴展,例如 VS Code 的 ESLint,以便在開發過程中獲得編輯器內的 linting 反饋。這樣可以避免在啟動開發伺服器時產生不必要的 linting 費用。
  2. 將 ESLint 作為生產建置命令的一部分執行,以便在部署到生產環境之前獲得完整的 linting 反饋。
  3. (可選)設置像 lint-staged 的工具,自動在 git 提交時檢查已修改的文件。

格式 - Formatting

Vue - 官方 VS Code 擴展提供 Vue SFC 的內建格式化支持。
另外,Prettier 也提供內建的 Vue SFC 格式化支持。

SFC 自訂區塊整合 - SFC Custom Block Integrations​

自訂區塊被編譯成對相同 Vue 文件的導入,並附有不同的請求查詢。這些導入請求的處理由底層的建置工具負責。

  • 如果使用 Vite,應使用自訂的 Vite 插件將匹配的自訂區塊轉換為可執行的 JavaScript。範例
  • 如果使用 Vue CLI 或普通的 webpack,則應配置 webpack loader 來轉換匹配的區塊。範例

低階套件 - Lower-Level Packages

@vue/compiler-sfc

文檔

此套件是 Vue 核心單一庫的一部分,始終與主 Vue 套件發佈相同版本。它作為主 Vue 套件的依賴關係被包含,並通過 vue/compiler-sfc 進行代理,因此無需單獨安裝。

該套件本身提供用於處理 Vue SFC 的低階工具,僅適用於需要在自訂工具中支持 Vue SFC 的工具開發者。

提示: 始終通過 vue/compiler-sfc 深度導入來使用此套件,因為這樣可以確保其版本與 Vue 執行時保持同步。

@vitejs/plugin-vue

文檔

官方插件,提供 Vite 中的 Vue SFC 支持。

vue-loader

文檔

官方 loader,提供 webpack 中的 Vue SFC 支持。如果您正在使用 Vue CLI,還可以參考有關修改 Vue CLI 中 vue-loader 選項的文檔

其他在線遊樂場 - Other Online Playgrounds

好多開發工具唷!好的框架工具少不了!!!
什麼時候我也來開發一款工具 www


avatar-img
2會員
71內容數
分享生活趣事~
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
卡關的人生 的其他內容
Vue 單文件元件(SFC)是 *.vue 文件,將模板、邏輯和樣式封裝在一個文件中,提供模組化開發。SFC 需建置步驟,但帶來多項好處,如元件範圍內的 CSS、預編譯模板和熱模塊替換(HMR)。適合單頁應用、靜態網站生成等前端專案。
<Suspense> 是 Vue 3 的一個實驗性組件,用於協調異步組件的加載狀態,簡化異步處理。它能在等待多個嵌套組件的異步依賴解決時顯示加載指示器,避免每個組件獨立處理加載和錯誤狀態,從而提高用戶體驗。
<Teleport> 是 Vue.js 的內建組件,允許我們將組件的部分內容「傳送」到 DOM 的不同位置,即使這些內容邏輯上屬於某個組件,但可以在視覺上顯示在其他位置,常用於模態框和覆蓋層等情境。
學會了使用 <KeepAlive>,這是一個內建組件,允許我們在動態切換多個組件時有條件地緩存組件實例,避免狀態丟失並提高速度。使用 include 和 exclude 屬性來自定義緩存行為,並透過 max 屬性限制緩存的實例數量。
<TransitionGroup> 是一個內建組件,專為對列表中的元素或組件進行插入、移除和順序變更的動畫處理而設計。與 <Transition> 的主要區別在於,<TransitionGroup> 預設不會渲染包裹元素,且不支持轉場模式。
<Transition> 用於元素或組件進入和離開 DOM 時的動畫,而 <TransitionGroup> 則應用於 v-for 列表的插入、移除或移動。這些組件透過 CSS 類別來控制動畫,例如進入/離開的狀態類別。可以透過 name 屬性自訂過渡效果的命名。
Vue 單文件元件(SFC)是 *.vue 文件,將模板、邏輯和樣式封裝在一個文件中,提供模組化開發。SFC 需建置步驟,但帶來多項好處,如元件範圍內的 CSS、預編譯模板和熱模塊替換(HMR)。適合單頁應用、靜態網站生成等前端專案。
<Suspense> 是 Vue 3 的一個實驗性組件,用於協調異步組件的加載狀態,簡化異步處理。它能在等待多個嵌套組件的異步依賴解決時顯示加載指示器,避免每個組件獨立處理加載和錯誤狀態,從而提高用戶體驗。
<Teleport> 是 Vue.js 的內建組件,允許我們將組件的部分內容「傳送」到 DOM 的不同位置,即使這些內容邏輯上屬於某個組件,但可以在視覺上顯示在其他位置,常用於模態框和覆蓋層等情境。
學會了使用 <KeepAlive>,這是一個內建組件,允許我們在動態切換多個組件時有條件地緩存組件實例,避免狀態丟失並提高速度。使用 include 和 exclude 屬性來自定義緩存行為,並透過 max 屬性限制緩存的實例數量。
<TransitionGroup> 是一個內建組件,專為對列表中的元素或組件進行插入、移除和順序變更的動畫處理而設計。與 <Transition> 的主要區別在於,<TransitionGroup> 預設不會渲染包裹元素,且不支持轉場模式。
<Transition> 用於元素或組件進入和離開 DOM 時的動畫,而 <TransitionGroup> 則應用於 v-for 列表的插入、移除或移動。這些組件透過 CSS 類別來控制動畫,例如進入/離開的狀態類別。可以透過 name 屬性自訂過渡效果的命名。
你可能也想看
Google News 追蹤
Thumbnail
現代社會跟以前不同了,人人都有一支手機,只要打開就可以獲得各種資訊。過去想要辦卡或是開戶就要跑一趟銀行,然而如今科技快速發展之下,金融App無聲無息地進到你生活中。但同樣的,每一家銀行都有自己的App時,我們又該如何選擇呢?(本文係由國泰世華銀行邀約) 今天我會用不同角度帶大家看這款國泰世華CUB
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
如何在 Vite 專案中安裝和設置 TypeScript 及路徑別名的步驟,包括安裝必要的依賴、配置 vite.config.js、tsconfig.json 的設置,及如何創建類型聲明文件來正確識別 .vue 文件。
Thumbnail
一開始你先把你的專案push上去後,修改vite.config.ts ,要在裡面新增  base: "/Cart/" (/放自己的專案名稱/) build: {outDir: "docs"}, 接下來你要去你的github setting 裡面 -> Page ->選Deploy fro
Thumbnail
你好,在下最近在學習開發web,學了html css js,也得出一些心得,由於網路上已有許多教學,所以我會著重在如何開發出to do List,以及解釋我寫的程式碼。相關的教學我會直接貼網址。如果我有什麼地方出錯,或者是可以寫得更好,歡迎在下方留言,討論。 首先先介紹我的開發環境: 我用了vs
Thumbnail
理解一個全新的操作環境有時候可能是一個挑戰,尤其對於那些剛開始接觸VS Code的開發者來說,即便具備一定的英文閱讀能力,可能也會對這個陌生的操作環境感到徬徨和不安。不過,沒有必要擔心,我們接下來就來一起用短短的一分鐘時間,將VS Code轉換成最熟悉的中文環境吧! 安裝繁體中文語言包 由於VS
Thumbnail
# 簡介 身為一位專注於 Vue.js 的前端開發者,這是我第一次嘗試構建 Flutter 網頁應用。讓我們開始吧! ## 第一次嘗試 ### 第一步:創建一個 Flutter 應用 首先,通過運行以下命令來創建一個新的 Flutter 項目: ```sh flutter
Thumbnail
因為最近想嘗試編碼風格,於是就選了一套比較"不嚴格"的輔助工具來摸索。 編輯器 VS CODE 框架 VUE3 打包工具 VITE 編碼風格 Standard 環境 version { "nodejs":"v18.18.0", "npm":"9.8.1" }
Thumbnail
平常我們在 html 上常看到的例如 v-for、v-model 等等... 也是VUE已經幫我們定義好的指令,而這次我們可以依這自己的需求來建立。 此功能屬於較進階的功能,因此實戰中會比較少見,市面上還是有不少完善的套件能達到同樣效果,建議可以先往這方面察找
我給予他們很簡單的定義,工具就是只需要滿足一邊的需求,平台需要同時滿足雙邊的需求。單就定義就可以很單純的知道創業作工具類的題目所需資源會遠低於平台,而兩者其實並不互斥,工具可以發展成平台,平台可以擁有許多工具。工具或是平台的定位對於商業模式會有很大的差異。
Thumbnail
現代社會跟以前不同了,人人都有一支手機,只要打開就可以獲得各種資訊。過去想要辦卡或是開戶就要跑一趟銀行,然而如今科技快速發展之下,金融App無聲無息地進到你生活中。但同樣的,每一家銀行都有自己的App時,我們又該如何選擇呢?(本文係由國泰世華銀行邀約) 今天我會用不同角度帶大家看這款國泰世華CUB
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
如何在 Vite 專案中安裝和設置 TypeScript 及路徑別名的步驟,包括安裝必要的依賴、配置 vite.config.js、tsconfig.json 的設置,及如何創建類型聲明文件來正確識別 .vue 文件。
Thumbnail
一開始你先把你的專案push上去後,修改vite.config.ts ,要在裡面新增  base: "/Cart/" (/放自己的專案名稱/) build: {outDir: "docs"}, 接下來你要去你的github setting 裡面 -> Page ->選Deploy fro
Thumbnail
你好,在下最近在學習開發web,學了html css js,也得出一些心得,由於網路上已有許多教學,所以我會著重在如何開發出to do List,以及解釋我寫的程式碼。相關的教學我會直接貼網址。如果我有什麼地方出錯,或者是可以寫得更好,歡迎在下方留言,討論。 首先先介紹我的開發環境: 我用了vs
Thumbnail
理解一個全新的操作環境有時候可能是一個挑戰,尤其對於那些剛開始接觸VS Code的開發者來說,即便具備一定的英文閱讀能力,可能也會對這個陌生的操作環境感到徬徨和不安。不過,沒有必要擔心,我們接下來就來一起用短短的一分鐘時間,將VS Code轉換成最熟悉的中文環境吧! 安裝繁體中文語言包 由於VS
Thumbnail
# 簡介 身為一位專注於 Vue.js 的前端開發者,這是我第一次嘗試構建 Flutter 網頁應用。讓我們開始吧! ## 第一次嘗試 ### 第一步:創建一個 Flutter 應用 首先,通過運行以下命令來創建一個新的 Flutter 項目: ```sh flutter
Thumbnail
因為最近想嘗試編碼風格,於是就選了一套比較"不嚴格"的輔助工具來摸索。 編輯器 VS CODE 框架 VUE3 打包工具 VITE 編碼風格 Standard 環境 version { "nodejs":"v18.18.0", "npm":"9.8.1" }
Thumbnail
平常我們在 html 上常看到的例如 v-for、v-model 等等... 也是VUE已經幫我們定義好的指令,而這次我們可以依這自己的需求來建立。 此功能屬於較進階的功能,因此實戰中會比較少見,市面上還是有不少完善的套件能達到同樣效果,建議可以先往這方面察找
我給予他們很簡單的定義,工具就是只需要滿足一邊的需求,平台需要同時滿足雙邊的需求。單就定義就可以很單純的知道創業作工具類的題目所需資源會遠低於平台,而兩者其實並不互斥,工具可以發展成平台,平台可以擁有許多工具。工具或是平台的定位對於商業模式會有很大的差異。