JS開發node包并發布流程

開發一個可發布到 npm 的 JavaScript 插件,需要遵循標準的開發、測試、打包和發布流程。以下是詳細步驟指南:


1. 初始化項目

創建項目目錄并初始化 package.json

mkdir my-js-plugin
cd my-js-plugin
npm init -y
  • 手動修改 package.json,確保包含必要字段:
    {"name": "my-js-plugin",  // 插件名稱(npm 唯一)"version": "1.0.0",      // 初始版本"description": "A JavaScript plugin for XXX","main": "dist/index.js", // 入口文件(需編譯后路徑)"scripts": {"build": "rollup -c",  // 打包命令(示例用 Rollup)"test": "jest"        // 測試命令},"keywords": ["plugin", "javascript", "npm"],"author": "Your Name","license": "MIT","dependencies": {},"devDependencies": {}
    }
    

2. 開發插件代碼

創建源碼文件(ES6+ 語法)

mkdir src
touch src/index.js
  • 示例插件代碼src/index.js):
    export default class MyPlugin {constructor(options) {this.options = options;}greet() {console.log(`Hello, ${this.options.name || 'World'}!`);}
    }
    

3. 配置打包工具

推薦使用 RollupWebpack 打包(支持 ES Module 和 CommonJS)。

安裝 Rollup(示例)

npm install rollup @rollup/plugin-babel @rollup/plugin-commonjs @rollup/plugin-node-resolve --save-dev

創建 Rollup 配置文件(rollup.config.js

import babel from '@rollup/plugin-babel';
import commonjs from '@rollup/plugin-commonjs';
import resolve from '@rollup/plugin-node-resolve';export default {input: 'src/index.js',output: [{file: 'dist/index.js',format: 'umd',       // 兼容 CommonJS 和瀏覽器name: 'MyPlugin',    // 全局變量名},{file: 'dist/index.esm.js',format: 'esm',      // ES Module},],plugins: [resolve(),commonjs(),babel({ babelHelpers: 'bundled' }),],
};

配置 Babel(babel.config.json

npm install @babel/core @babel/preset-env --save-dev
{"presets": ["@babel/preset-env"]
}

運行打包

npm run build
  • 生成的文件在 dist/ 目錄下。

4. 添加單元測試

安裝 Jest

npm install jest --save-dev

創建測試文件(test/index.test.js

import MyPlugin from '../src/index';test('MyPlugin should greet correctly', () => {const plugin = new MyPlugin({ name: 'Alice' });expect(plugin.options.name).toBe('Alice');
});

運行測試

npm test

5. 準備發布

1. 注冊 npm 賬號

  • 在 npm 官網 注冊賬號。
  • 在終端登錄:
    npm login
    

2. 檢查 package.json 關鍵字段

  • name: 確保唯一性(可在 npm 官網搜索驗證)。
  • version: 遵循 語義化版本(如 1.0.0)。
  • main: 指向打包后的入口文件(如 dist/index.js)。

3. 添加 .npmignore(可選)

忽略不需要發布的文件(類似 .gitignore):

src/
test/
rollup.config.js
babel.config.json

6. 發布到 npm

npm publish
  • 首次發布需驗證郵箱。
  • 更新版本時:
    npm version patch  # 更新補丁版本(1.0.1)
    npm publish
    

7. 后續維護

  • 版本管理
    • npm version major|minor|patch 更新版本號。
  • 文檔
    • README.md 中寫明用法、API 和示例。
  • 持續集成
    • 可配置 GitHub Actions 自動測試和發布。

8.完整目錄結構

my-js-plugin/
├── dist/                # 打包后的文件
│   ├── index.js         # UMD 格式
│   └── index.esm.js     # ES Module 格式
├── src/
│   └── index.js         # 源碼
├── test/
│   └── index.test.js    # 測試代碼
├── package.json
├── rollup.config.js
├── babel.config.json
└── README.md

9. 本地調試和測試

在 npm 包未上傳到 npm 倉庫之前,可以進行本地調試和測試,使用 npm linknpm link 可以在本地創建符號鏈接,使得項目可以直接引用本地開發的 npm 包,而無需發布到 npm,步驟如下:

  1. 在 npm 包目錄下運行 npm link

    cd /path/to/your-package
    npm link
    

    這會在全局 node_modules 中創建一個軟鏈接,指向你的本地包。

  2. 在項目中鏈接該包

    cd /path/to/your-project
    npm link your-package-name
    

    這樣,項目中的 node_modules/your-package-name 會指向本地包目錄。

  3. 測試修改

    • 修改本地包代碼后,項目會自動獲取最新更改,無需重新安裝。
    • 適用于快速迭代開發。
  4. 取消鏈接

    npm unlink your-package-name  # 在項目中取消鏈接
    cd /path/to/your-package && npm unlink  # 在包目錄取消全局鏈接
    

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/86632.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/86632.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/86632.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

對比學習(Contrastive Learning)方法詳解

對比學習(Contrastive Learning)方法詳解 對比學習(Contrastive Learning)是一種強大的自監督或弱監督表示學習方法,其核心思想是學習一個嵌入空間,在這個空間中,相似的樣本(“正樣…

1.6 http模塊nodejs 對比 go

我們以go語言 原生實現 和瀏覽器交互.到現在學習 nodejs http模塊. nodejs 對于請求分發,也需要我們自己處理. 我們應該也對 http 服務是建立在 tcp協議基礎上.有更深入的體會了吧. 對于我們之后 學習 java web容器. 能有更深入的認知. 請求分發 請求分發是指 Web 框架或服務器…

護照閱讀器在景區的應用

護照閱讀器在景區的應用可以顯著提升游客管理效率、增強安全性并優化游客體驗。以下是其主要應用場景、優勢及實施建議: 一、核心應用場景 快速入園核驗 自動身份識別:通過掃描護照芯片(MRZ碼或NFC讀取),1-3秒完成身份…

Prompt Tuning、P-Tuning、Prefix Tuning的區別

一、Prompt Tuning、P-Tuning、Prefix Tuning的區別 1. Prompt Tuning(提示調優) 核心思想:固定預訓練模型參數,僅學習額外的連續提示向量(通常是嵌入層的一部分)。實現方式:在輸入文本前添加可訓練的連續向量(軟提示),模型只更新這些提示參數。優勢:參數量少(僅提…

什么是遙測數據?

遙測數據定義 遙測數據提供了關于系統性能的重要洞察,對主動解決問題和做出明智決策至關重要。要實現這一點,不能只依賴原始數據 —— 你需要實時的洞察,而這正是遙測數據提供的。 遙測是從遠程來源(如服務器、應用程序和監控設…

【JavaAPI搜索引擎】項目測試報告

JavaAPI搜索引擎測試報告 項目背景與項目介紹項目功能自動化測試單元測試測試ansj分詞器測試能否獲取到正確的URL測試能否正確解析文件中的正文 測試計劃界面測試測試1 頁面布局是否合理美觀,元素是否正確顯示測試2 測試是否可以正常顯示出搜索結果測試3 點擊搜索結…

如何選擇合適的IP輪換周期

選擇合適的IP輪換周期需綜合業務目標、目標平臺風控規則、IP類型與質量等多維度因素,以下是系統化決策框架及實操建議: 🔄 一、核心決策要素 業務場景類型 高頻操作型(如數據采集、廣告點擊): 輪換周期短&a…

GO Goroutine 與并發模型面試題及參考答案

目錄 什么是 Goroutine,它與線程有何區別? 如何創建一個 Goroutine?有哪些方式? Goroutine 執行函數時傳遞參數應注意什么問題? 使用 Goroutine 時如何確保主線程不會提前退出? 多個 Goroutine 寫共享變量時會出現什么問題?如何解決? 如何用 sync.WaitGroup 管理 …

Leetcode-11 2 的冪

Leetcode-11 2 的冪(簡單) 題目描述思路分析通過代碼(python) 題目描述 給你一個整數 n,請你判斷該整數是否是 2 的冪次方。如果是,返回 true ;否則,返回 false 。 如果存在一個整數…

【Java】【力扣】121.買賣股票的最佳時機

思路 所以后續的每次都是在&#xff1a;1-判斷是否更新最低點 2-如果不需要更新最低點 則計算差值 代碼 class Solution { public int maxProfit(int[] prices) { int minprices[0]; int max0; for (int i 1; i < prices.length; i) { //假設0就是最低點 // 判…

微服務架構下大型商城系統的事務一致性攻堅:Saga、TCC與本地消息表的實戰解析

當用戶在商城完成支付卻看到"訂單異常"提示時&#xff0c;背后往往是分布式事務一致性缺失導致的業務裂縫。在微服務拆分的商城系統中&#xff0c;如何保障跨服務的交易原子性&#xff0c;成為架構設計的生死線。 一、商城分布式事務的典型場景與痛點 在某家電品牌商…

深入理解 Vue.observable:輕量級響應式狀態管理利器

目錄 引言 一、什么是 Vue.observable&#xff1f; 二、為什么需要 Vue.observable&#xff1f;解決什么問題&#xff1f; 三、核心原理&#xff1a;響應式系統如何工作 四、如何使用 Vue.observable 功能說明 技術要點 五、關鍵注意事項與最佳實踐 六、實際應用案例 …

JS設計模式(5): 發布訂閱模式

解鎖JavaScript發布訂閱模式&#xff1a;讓代碼溝通更優雅 在JavaScript的世界里&#xff0c;我們常常會遇到這樣的場景&#xff1a;多個模塊之間需要相互通信&#xff0c;但是又不想讓它們產生過于緊密的耦合。這時候&#xff0c;發布訂閱模式就像一位優雅的信使&#xff0c;…

【電路物聯網】SDN架構與工作原理介紹

(??? )&#xff0c;Hello我是祐言QAQ我的博客主頁&#xff1a;C/C語言&#xff0c;數據結構&#xff0c;Linux基礎&#xff0c;ARM開發板&#xff0c;網絡編程等領域UP&#x1f30d;快上&#x1f698;&#xff0c;一起學習&#xff0c;讓我們成為一個強大的攻城獅&#xff0…

vscode 保存 js 時會自動格式化,取消設置也不好使

vscode 里的設置搜索 Editor: Format On Save 取消勾選 卸載 Prettier - Code formatter 這個插件后好使了&#xff0c;本來以為是插件的問題&#xff0c;后來發現是工作區設置的問題。 因為我是用 GitHub 下載的工程打開后&#xff0c; vscode 認為是工作區了, 因為 .vscode…

xcode中project.pbxproj點開為空白問題

由于需要修改signing里面的配置&#xff0c;點擊了project.pbxproj。但是發現一片空白&#xff0c;如圖 以為是配置文件損壞&#xff0c;郵件show in Finder看了一通后沒看出什么所以然。并且發現entitlement文件、list文件全都是點開為白&#xff0c;并且沒有任何保存 最后發…

JUC并發編程(四)常見模式

目錄 一 同步與協調模式 1 保護性暫停模式 2 順序控制模式 3 生產者消費者模式 4 Balking模式&#xff08;猶豫模式&#xff09; 二 線程管理/生命周期模式 1 兩階段終止模式 一 同步與協調模式 1 保護性暫停模式 一個線程需要等待另一個線程提供特定條件&#xff08;通常是…

Vue 數據代理機制對屬性名的要求

Vue 數據代理機制對屬性名的要求 在 Vue 的數據代理機制中,屬性名需遵循以下關鍵規則: 1. 禁止以 _ 或 $ 開頭 ?? Vue 會跳過代理以 _ 或 $ 開頭的屬性原因:這些前綴被 Vue 保留用于內部屬性(如 _data, _uid, $refs, $el 等)示例:data() {return {count: 1, // ?…

pdf.js在iOS移動端分頁加載優化方案(ios移動端反復刷新加載問題)

背景與問題 在iOS移動端加載大型PDF文件時&#xff0c;由于設備內存限制&#xff0c;經常遇到以下問題&#xff1a; 內存不足導致頁面崩潰大文件加載緩慢頁面反復重新加載 ##解決方案 采用PDF.js的分頁加載策略&#xff0c;實現按需加載當前可視頁面及相鄰頁面&#xff0c;…

【C++】來學習使用set和map吧

各位大佬好&#xff0c;我是落羽&#xff01;一個堅持不斷學習進步的大學生。 如果您覺得我的文章有所幫助&#xff0c;歡迎多多互三分享交流&#xff0c;一起學習進步&#xff01; 也歡迎關注我的blog主頁: 落羽的落羽 文章目錄 一、set和map是什么二、set系列1. set2. mult…