本週在我的開源課程中,我和我的同學的任務是將我們自己的每個程式發佈到包註冊表。
當你聽到有人說代碼註冊表、包註冊表或註冊表時,我喜歡將這些詞視為代表開發人員和公司發布代碼供其他人下載的地方。想要更精確的描述,可以閱讀Mozilla的這篇文章:

套件管理基礎 - 學習 Web 開發 | MDN
我們的套件管理器之旅到此結束。我們的下一步是建立一個範例工具鏈,將我們迄今為止學到的所有知識付諸實踐。

gimme_readme - npm
gimme_readme 是一個由 AI 提供支援的命令列工具,可為您的專案產生全面的 README.md 檔案。它一次分析多個原始碼文件,提供每個文件的用途、功能和關鍵組件的簡明解釋。最新版本:1.0.0,最後發布:16 小時前。透過執行「npm i gimme_readme」開始在專案中使用 gimme_readme。 npm 註冊表中沒有其他項目使用 gimme_readme。

正如您在上面所看到的,有很多資料夾和檔案對於使用者(而不是開發人員)來說是不必要的。例如,您認為我的用戶會希望我的“tests”資料夾來測試我的程式碼嗎? 可能不是。您認為我的用戶需要格式化和檢查我的原始程式碼所需的設定檔嗎? 可能不是。您認為我的用戶是否出於任何特定原因需要使用我的“.github”資料夾? 可能不是。
為此,我一直在努力尋找一種解決方案來最大程度地減少用戶下載的內容;具體來說,我希望他們只擁有我的程式運行所需的原始碼。
是 .npmignore 還是不 .npmignore?這就是問題所在。
當我考慮重新發布我的程式碼時,我也在和我的朋友 Uday Rana 討論使用 .npmignore 文件來「忽略」我不想發布的文件的想法。
就在我提到這個主題之後,Uday 在Google 上搜尋了.npmignore,並找到了Jeff D 撰寫的一篇關於為什麼人們應該永遠不會使用. npmignore 文件的文章。需要明確的是,我完全同意傑夫的文章。
本質上,這個想法是我們應該明確我們想要發布的內容(白名單),而不是說明我們不 想要發布(列入黑名單)。
使用 npm 將我們想要發布的文件列入白名單非常簡單。我們需要做的就是透過新增「files」選項來編輯 package.json 文件,該選項指示我們要為程式發布哪些文件。下面,我截取了 package.json 的「files」選項的螢幕截圖,該選項指出「發布此程式時包含 src/ 目錄」。我已經提交了這些更改,並且這些更改可在我的程式碼 v1.0.0 版本中使用。
注意:預設情況下,某些檔案總是發佈到 npm,無論您在「檔案」選項中指定或未指定什麼。如果你想了解更多如何使用「files」選項,請查看 npm 的官方文件如何使用 file 選項。
使用更新後的 package.json 將我的程式碼發佈到 npm 後,安裝/重新安裝 gimme_readme 的用戶現在電腦上的膨脹會少很多!請參閱以下差異:
新增 GitHub 操作以在新增版本時將程式碼發佈到 npm
除了增強用戶體驗(透過減少透過npm 安裝gimme_readme 帶來的臃腫)之外,我還添加了一個持續開發管道(簡稱cd 管道),當我創建新的專案時,它可以將我的發布流程自動化到npm在GitHub 上發布。有關如何執行此操作的具體詳細信息,您可以參閱 GitHub 的發布 Node.js 包指南。現在感覺很好,因為只需點擊幾個按鈕,我就可以發布我知道穩定的程式碼(根據我的 CI 管道),來自 GitHub。
您可以在這裡找到我的 cd 管道的程式碼。
與烏代一起測試
正如我之前提到的,我正在與我的朋友 Uday Rana 一起進行測試。在撰寫本文時,他能夠安裝我的工具,並像這樣使用它:
事情對我來說看起來不錯,而且我的工具的大多數選項或多或少都符合他的預期。但我必須再次重複這個過程,因為我想添加一些進一步的優化!
旅程永無止境……但這就是它的樂趣所在!
我最近也聽說了進一步優化我的程式碼的方法。特別是,我致力於學習如何透過了解複合操作以及與 GitHub 操作相關的可重複使用工作流程來改善我的 CI 和 CD 管道。我希望這些技術能幫助我減少編寫的程式碼量,並提供某種類型的效能提升!我對這些主題還不太了解,但你可以打賭我可能很快就會在部落格上介紹它。
我的朋友們,結束了我想在這個部落格中談論的內容。
下次見!
以上是使用 GitHub Actions 將 gimme_readme 重新發佈到 npm的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

10款趣味橫生的jQuery遊戲插件,讓您的網站更具吸引力,提升用戶粘性!雖然Flash仍然是開發休閒網頁遊戲的最佳軟件,但jQuery也能創造出令人驚喜的效果,雖然無法與純動作Flash遊戲媲美,但在某些情況下,您也能在瀏覽器中獲得意想不到的樂趣。 jQuery井字棋遊戲 遊戲編程的“Hello world”,現在有了jQuery版本。 源碼 jQuery瘋狂填詞遊戲 這是一個填空遊戲,由於不知道單詞的上下文,可能會產生一些古怪的結果。 源碼 jQuery掃雷遊戲

本教程演示瞭如何使用jQuery創建迷人的視差背景效果。 我們將構建一個帶有分層圖像的標題橫幅,從而創造出令人驚嘆的視覺深度。 更新的插件可與JQuery 1.6.4及更高版本一起使用。 下載

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。

Matter.js是一個用JavaScript編寫的2D剛體物理引擎。此庫可以幫助您輕鬆地在瀏覽器中模擬2D物理。它提供了許多功能,例如創建剛體並為其分配質量、面積或密度等物理屬性的能力。您還可以模擬不同類型的碰撞和力,例如重力摩擦力。 Matter.js支持所有主流瀏覽器。此外,它也適用於移動設備,因為它可以檢測觸摸並具有響應能力。所有這些功能都使其值得您投入時間學習如何使用該引擎,因為這樣您就可以輕鬆創建基於物理的2D遊戲或模擬。在本教程中,我將介紹此庫的基礎知識,包括其安裝和用法,並提供一

本文演示瞭如何使用jQuery和ajax自動每5秒自動刷新DIV的內容。 該示例從RSS提要中獲取並顯示了最新的博客文章以及最後的刷新時間戳。 加載圖像是選擇


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3漢化版
中文版,非常好用

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Dreamweaver Mac版
視覺化網頁開發工具