」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > tsup 捆綁您的 TypeScript 套件

tsup 捆綁您的 TypeScript 套件

發佈於2024-09-01
瀏覽:728

您正在建立 TypeScript 庫但不確定如何捆綁它?我推薦tsup。

以下是我考慮的因素:

1. NPM 註冊中心每週下載量超過 100 萬次

2. tsup 儲存庫有 8.6k 顆星,正在積極維護。

3. 有據可查。

4. 用於shadcn-ui/ui CLI包。

5. tsup內部使用rollup。

我查看了 tsup 原始碼,它有 Nodejs 工作線程相關程式碼,其中包含各種推播訊息並監聽它們。這學習起來會很有趣,這也意味著我將進入一個與捆綁商打交道的不同領域。還不確定…

tsup to bundle your TypeScript package

尋找 shadcn-ui/ui 中使用的 tsup 在許多方面對您有幫助:

1.您將了解如何「可以」實現 tsup

- 您在 OSS 中找到的實作可以幫助您以更好的方式瀏覽文件。

- 閱讀整個文件很酷,但對我們中的一些人來說可能會不知所措。

2.透過閱讀 shadcn-ui 原始碼來查看它的實際效果。在 shadcn-ui/ui CLI 原始碼中搜尋 tsup 可以在兩個地方找到:

  • 包.json
"scripts": {  
 "dev": "tsup - watch",  
 "build": "tsup",
  • tsup.config.ts
import { defineConfig } from "tsup"  

export default defineConfig({  
 clean: true,  
 dts: true,  
 entry: \["src/index.ts"\],  
 format: \["esm"\],  
 sourcemap: true,  
 minify: true,  
 target: "esnext",  
 outDir: "dist",  
})

此時,我只需閱讀文件來了解這些選項是什麼以及腳本是如何配置的。

這樣我就不會因為文件而感到不知所措,而且我確切地知道我在尋找什麼。這是我設定從文件中閱讀和學習最多方向的方式。

首先,我在開源 CLI 相關套件中也是這樣做的,以捆綁我的 TS 庫。

想學習如何從頭開始建立 shadcn-ui/ui 嗎?查看 從頭開始建構

關於我:

網址:https://ramunarasinga.com/

Linkedin:https://www.linkedin.com/in/ramu-narasinga-189361128/

Github:https://github.com/Ramu-Narasinga

電子郵件:[email protected]

從頭開始建構 shadcn-ui/ui

參考:

1. tsup 文件:https://tsup.egoist.dev/

2. npm: https://www.npmjs.com/package/tsup

3. tsup在shadcn-ui/ui中的使用:https://github.com/shadcn-ui/ui/blob/main/packages/cli/package.json#L33

4.我的開源CLI相關專案:https://github.com/Ramu-Narasinga/TThroo/blob/main/packages/cli/package.json#L35

版本聲明 本文轉載於:https://dev.to/ramunarasinga/tsup-to-bundle-your-typescript-package-1ln2?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 關於測試覆蓋率的真相
    關於測試覆蓋率的真相
    一個強而有力的真理。 看下面這段簡單明了的程式碼: function sum(a, b) { return a b; } 現在,讓我們為它寫一些測試: test('sum', () => { expect(sum(1, 2)).toBe(3); expect(...
    程式設計 發佈於2024-11-06
  • 為什麼我的 OpenGL 三角形無法在 Go 中渲染?調查頂點緩衝區問題。
    為什麼我的 OpenGL 三角形無法在 Go 中渲染?調查頂點緩衝區問題。
    Go 中的OpenGL 頂點緩衝區問題在Go 中嘗試使用OpenGL 顯示三角形時,使用者遇到了頂點緩衝區問題緩衝區無法渲染形狀。 Go 程式碼源自於教程,但與 C 程式碼不同的是,它沒有產生任何輸出。 問題原因問題的根本原因位於傳遞給 vertexAttrib.AttribPointer() 的參...
    程式設計 發佈於2024-11-06
  • 為什麼在 Linux 32 位元發行版上的 Go 程式中設定 `ulimit -n` 會導致「參數無效」錯誤?
    為什麼在 Linux 32 位元發行版上的 Go 程式中設定 `ulimit -n` 會導致「參數無效」錯誤?
    如何在 Go 程式中設定 ulimit -n? 問題使用者嘗試在 Go 程式中設定 ulimit -n使用 setrlimit 和 getrlimit 系統呼叫將其限制在程式內而不是全域。然而,在嘗試設定該值時出現錯誤,提示「參數無效」。 解決方案發現問題是由於 Linux 32 的 Getrlim...
    程式設計 發佈於2024-11-06
  • 如何在Python中創建無限深度的動態嵌套字典?
    如何在Python中創建無限深度的動態嵌套字典?
    未定義深度的動態嵌套字典在涉及複雜多層資料結構的場景中,經常會遇到變數嵌套字典的需求水平。雖然硬編碼插入語句是一種潛在的解決方案,但當事先未知嵌套深度時,這種方法是不切實際的。 要克服此限制,請考慮利用 Python 的 collections.defaultdict,它允許動態建立字典。可以使用下...
    程式設計 發佈於2024-11-06
  • Python 變得強大:輕鬆程式設計的初學者指南
    Python 變得強大:輕鬆程式設計的初學者指南
    Python 是一門強大的程式語言,文法簡單,應用廣泛。安裝 Python 後,可以學習其基本語法,包括變數賦值、資料類型和流程控制。實戰案例中,我們透過蒙特卡羅模擬計算圓周率,展示了 Python 在數值計算中的能力。此外,Python 擁有豐富的函式庫,涵蓋機器學習、資料分析和網路開發等領域,體...
    程式設計 發佈於2024-11-06
  • 如何在沒有 jQuery 的情況下監聽動態建立的元素的事件?
    如何在沒有 jQuery 的情況下監聽動態建立的元素的事件?
    在沒有 jQuery 的情況下監聽動態創建的元素的事件使用外部頁面時,向動態生成的元素添加事件監聽器可能具有挑戰性。在這種情況下,委派事件處理至關重要。 一種方法是使用 event.target 屬性來檢查單擊或觸發的元素是否屬於所需類型。這是一個例子:document.querySelector(...
    程式設計 發佈於2024-11-06
  • 利用 Snipbyte 的高階考勤管理系統優化勞動力效率
    利用 Snipbyte 的高階考勤管理系統優化勞動力效率
    在當今的商業環境中,有效管理員工出勤、輪班和工資單可以決定組織的成功或失敗。準確的考勤追蹤不僅可以確保營運順利進行,還有助於提高生產力。在 Snipbyte,我們專注於提供一流的基於網路的解決方案來增強業務流程,包括我們的高級考勤管理系統。 為什麼選擇Snipbyte的考勤管理系統? 我們的考勤...
    程式設計 發佈於2024-11-06
  • Laravel Auth 路由教程
    Laravel Auth 路由教程
    Laravel auth routes is one of the essential features of the Laravel framework. Using middlewares you can implement different authentication strategies...
    程式設計 發佈於2024-11-06
  • 如何有效地跳到大型文字檔案中的特定行?
    如何有效地跳到大型文字檔案中的特定行?
    優化大型文字檔案中的跳行:另一種方法處理大量不同長度行的文字檔案時,通常效率很低順序讀取每一行以達到特定的行號。問題中提供的程式碼範例說明了這種方法,需要對整個文件進行可能緩慢的迭代。然而,還有一種替代方法可以透過利用計算出的偏移列表來優化跳線。 基於偏移的跳線要克服這項挑戰,需要一種更有效的方法涉...
    程式設計 發佈於2024-11-06
  • 如何在 JavaScript 中檢索 HTML 元素的 CSS 屬性值?
    如何在 JavaScript 中檢索 HTML 元素的 CSS 屬性值?
    在 JavaScript 中取得 HTML 元素的 CSS 屬性值在 Web 開發中,動態操作 CSS 屬性可以增強使用者體驗和介面。使用 JavaScript,存取這些屬性非常簡單。 在您的場景中,CSS 檔案連結到 HTML 頁面,您需要檢索類別名稱為「的 div 的特定屬性(例如顏色)」佈局。...
    程式設計 發佈於2024-11-06
  • PLSQL 中的 DBMS_OUTPUT.PUT_LINE
    PLSQL 中的 DBMS_OUTPUT.PUT_LINE
    在 Oracle PL/SQL 中,列印輸出的方法是使用 DBMS_OUTPUT.PUT_LINE 程序。此程序將文字寫入控制台或輸出緩衝區,如果啟用了 DBMS_OUTPUT,則可以在執行後查看文字。使用方法如下: 首先,在 SQL 環境(如 SQL*Plus 或 Oracle SQL Devel...
    程式設計 發佈於2024-11-06
  • 利用 Python 實現自動化:用程式碼簡化日常任務
    利用 Python 實現自動化:用程式碼簡化日常任務
    介紹 Python 已成為從 Web 開發到資料科學等各種應用程式的首選語言。 Python 真正大放異彩的領域之一是自動化。無論您是希望自動化平凡的任務、簡化工作流程,還是創建強大的腳本來節省時間和精力,Python 的簡單性和多功能性都使其成為完成這項工作的完美工具。 ...
    程式設計 發佈於2024-11-06
  • 如何在 Python 中傳遞參數來應用 Pandas 系列的函數?
    如何在 Python 中傳遞參數來應用 Pandas 系列的函數?
    Python Pandas 中向Series Apply 函數傳遞參數pandas 庫提供了'apply()' 方法將函數應用於Series 的每個元素。然而,舊版的 pandas 不允許向函數傳遞額外的參數。 舊版Pandas 的解決方案:在舊版中處理此限制pandas 中,您可以...
    程式設計 發佈於2024-11-06
  • 如何使用 Java 8 Lambda 以多個欄位有效地對集合進行排序?
    如何使用 Java 8 Lambda 以多個欄位有效地對集合進行排序?
    使用 Java 8 Lambda 對具有多個欄位的集合進行排序提供的排序程式碼似乎不完整,可能不會產生預期的排序順序。讓我們深入研究使用 Java 8 lambda 的更有效率、更全面的方法。 使用 Java 8 lambda 的Java 8 透過提供直覺的 lambda 表達式來簡化清單排序,這些...
    程式設計 發佈於2024-11-06
  • 開發人員如何使用 JavaScript 在 HTML 頁面之間安全地交換資料?
    開發人員如何使用 JavaScript 在 HTML 頁面之間安全地交換資料?
    在JavaScript 中維護HTML 頁面之間的資料完整性在網頁之間傳輸資料時,使用查詢參數的傳統方法(例如「http:/ /localhost/ project/index.html?status=exist") 可能會在URL 中暴露敏感資訊。為了解決這個問題,開發人員尋求安全交換資...
    程式設計 發佈於2024-11-06

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3