Vue3 企業級優雅實戰

2022-11-15 15:00:47

該系列已更新文章:
分享一個實用的 vite + vue3 元件庫腳手架工具,提升開發效率
開箱即用 yyg-cli 腳手架:快速建立 vue3 元件庫和vue3 全家桶專案
Vue3 企業級優雅實戰 - 元件庫框架 - 1 搭建 pnpm monorepo
Vue3 企業級優雅實戰 - 元件庫框架 - 2 初始化 workspace-root
Vue3 企業級優雅實戰 - 元件庫框架 - 3 搭建元件庫開發環境
Vue3 企業級優雅實戰 - 元件庫框架 - 4 元件庫的 CSS 架構

本文繼續元件庫開發環境的搭建,前面兩篇分別介紹了元件庫中元件專案的初始化、元件庫 CSS 架構,本文介紹通用工具庫的搭建。在元件開發過程中,可能會呼叫一些通用的工具函數,這些工具函數便可以提取到一個獨立的 npm 包中。

1 建立工具包

1.1 初始化工具包

到目前為止,packages 目錄下有三個包:foo 範例元件、scss 樣式、yyg-demo-ui 元件庫聚合,現建立第四個:utils

在命令列中進入 utils 目錄,使用 pnpm 初始化。

pnpm init

修改自動生成的 package.json 檔案中的 namemain ,內容如下:

{
  "name": "@yyg-demo-ui/utils",
  "version": "1.0.0",
  "description": "通用工具函數",
  "main": "index.ts",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [],
  "author": "",
  "license": "ISC"
}

由於工具包咱們也採用 TypeScript 編寫,在 utils 下也提供一份 tsconfig.json 檔案:

{
  "compilerOptions": {
    "target": "es2015",
    "lib": [
      "es2015"
    ],
    "module": "commonjs",
    "rootDir": "./",
    "allowJs": true,
    "isolatedModules": false,
    "esModuleInterop": true,
    "forceConsistentCasingInFileNames": true,
    "strict": true,
    "skipLibCheck": true
  }
}

1.2 編寫第一個工具函數

需求描述:元件間通訊是一個剛需,當元件層級較多時,可以使用全域性匯流排來通訊。Vue 2.x 中通常使用 EventBus 作為全域性匯流排,而 Vue 3.x 可以使用 mittmitt 體積小,支援全部事件的監聽和批次移除,不依賴 Vue 範例,可以跨框架使用。咱們的第一個工具函數就是簡單封裝 mitt,匯出 mitt 物件即可。

首先在 utils 包下安裝 mitt 依賴:

pnpm install [email protected]

細心的同學會發現,在引入 mitt 時優雅哥指定了版本號 1.1.3,這是因為,優雅哥在使用當前最新的 3.0.0 版本時一直提示型別錯誤或找不到型別宣告檔案,由於沒空處理,就簡單粗暴的降到 1.1.3 版本。

utils 目錄下建立原始碼目錄 src,並在 src 中建立 emitter.ts 檔案。

utils/src/emitter.ts

import mitt from 'mitt'
const Mitt = mitt
export const emitter: mitt.Emitter = new Mitt()

export default emitter

上面的第二行程式碼看著多餘,因為本質上就是 new mitt(),這麼做是為了滿足 eslint 的規則:

A constructor name should not start with a lowercase letter.

1.3 編寫第二個工具函數

上面的 emitter 物件會在後面的元件開發中使用到,在 foo 中並未使用到,所以咱們再建立一個測試使用的工具函數。

utils/src/ 目錄下建立 test-log.ts 檔案:

export const testLog = (str: string) => {
  console.log('test log: ', str)
}

1.4 入口檔案

前面的 package.json 中指定了 mainindex.ts,在 utils 目錄下建立 index.ts 檔案,匯入並匯出所有的工具函數等。

export { emitter } from './src/emitter'
export { testLog } from './src/test-log'

總結一下,元件庫通用工具包的目錄結構如下:

packages/
  |- utils/
    |- src/
        |- emitter.ts
        |- test-log.ts
    |- index.ts
    |- tsconfig.json
    |- package.json

2 在元件中使用工具包

2.1 安裝依賴

前面已經開發了 foo 範例元件,如果該元件要使用工具包,首先需要安裝依賴。在命令列中進入 foo 目錄:

pnpm install @yyg-demo-ui/utils

執行後 foo 的 package.json 中會多了一行依賴:

"dependencies": {
  "@yyg-demo-ui/utils": "workspace:^1.0.0"
}

2.2 使用工具

由於 utils 包指定了 mainindex.ts,並且所有的工具都在 index.ts 中匯入並匯出,所以在使用時只需引入 utils 包即可。

例如要使用上面建立的 testLog 函數,則只需要在程式碼中如下引入:

import { testLog } from '@yyg-demo-ui/utils'

setup 中的按鈕點選事件呼叫該方法:

const onBtnClick = () => {
  console.log('點選按鈕測試', props.msg)
  testLog(props.msg)
}

後面再開發過程中如果新增工具函數:如 JSON Schema 的解析等,則往 utils 中新增即可,並在 utils/index.ts 中統一將其匯入並匯出。

感謝你閱讀本文,如果本文給了你一點點幫助或者啟發,還請三連支援一下,點贊、關注、收藏,程式設計師優雅哥會持續與大家分享更多幹貨