【制作npm包4】api-extractor 學習

制作npm包目錄

本文是系列文章, 作者一個橙子pro,本系列文章大綱如下。轉載或者商業修改必須注明文章出處

一、申請npm賬號、個人包和組織包區別
二、了解 package.json 相關配置
三、 了解 tsconfig.json 相關配置
四、 api-extractor 學習
五、npm包制作完整教程,我的第一個npm包


api-extractor 學習

安裝

pnpm add @microsoft/api-extractor

簡述

還記得在 package.json 的配置當中,有一個types的配置項,這個配置項就是用來配置類型注釋的地址的。

我大致總結了以下幾種方式來生成類型注釋

方法描述
手寫可以自己在項目的根目錄創建.d.ts文件,但是比較費力
tsc生成官方支持,比較方便,但是文件零散,不利于包使用
打包插件生成類型注釋這個方法也十分省力,但是幾乎沒有官方插件,bug也是層出不窮

最后發現一種比較方便的工具,就是api-extractor了,這個文件是在vue官方的倉庫當中發現了這種類型打包方式。他的主要作用是將tsc生成的類型注釋,聚合成為單個文件,這樣一來對包的分發十分有利。

選擇這個工具的原因不僅僅是vue采用了這個打包方式,而且這種方式是微軟官方制作,不擔心跑路問題。

什么是 API Extractor

API Extractor 是一個 TypeScript 分析工具,可生成以下三種不同的文件類型:

  1. API Report 用于生成一個基礎的api流程
  2. .d.ts文件生成,是一個類型文件的打包工具,將分散的.d.ts文件進行聚合,如同vite打包成js文件是一個道理。
  3. docModel 生成一個簡單的api文檔

在一般的項目包制作過程當中,用到他的類型文件聚合能力。

配置

{"$schema": "https://developer.microsoft.com/json-schemas/api-extractor/v7/api-extractor.schema.json","projectFolder": ".","mainEntryPointFilePath": "./dist/types/index.d.ts", // 這個文件是打包的入口,通常是`tsc -b xxx` 編譯文件的輸出位置"dtsRollup": {"enabled": true // 這個配置設置為true,表示用于聚合生成`.d.ts`文件},"apiReport": {"enabled": false},"docModel": {"enabled": false},"tsdocMetadata": {"enabled": false},"messages": {"compilerMessageReporting": {"default": {"logLevel": "warning"}},"extractorMessageReporting": {"default": {"logLevel": "warning","addToApiReportFile": true},"ae-forgotten-export": {"logLevel": "none"},"ae-missing-release-tag": {"logLevel": "none"}},"tsdocMessageReporting": {"default": {"logLevel": "warning"},"tsdoc-undefined-tag": {"logLevel": "none"}}}
}

在項目根目錄創建api-extractor.json文件,將上述文件拷貝進去。

工作流程介紹

我們的項目一般存在若干的ts文件,當執行tsc進行編譯時,會對每一個文件生成對應的d.ts文件,但是這種方法并不符合實際。一般而言,在使用一個庫的時候,只會存在一個d.ts入口文件,而且這個文件用戶在使用時,只會安裝npm,直接導入對應api去使用,那么如果這個文件過于分散,可能會造成使用者的心理負擔。

所以,對于tsc編譯過的文件,再次通過api-extractor進行聚合是一種合適的方式。
在這里插入圖片描述

對于api-extractor 的介紹到這里就可以結束了,如果對他的配置項有興趣,可以直接參考官方網站1

打包配置可參考:https://github.com/vue3plugin/npm-pkg-by-vite/blob/main/package.json


  1. https://api-extractor.com/pages/overview/intro/ ??

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

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

相關文章

Dockerfile自定義鏡像

文章目錄 Dockerfile自定義鏡像鏡像結構Dockerfile語法構建java項目 小結 Dockerfile自定義鏡像 常見的鏡像在DockerHub就能找到,但是我們自己寫的項目就必須自己構建鏡像了。 而要自定義鏡像,就必須先了解鏡像的結構才行。 鏡像結構 鏡像是將應用程序及…

服務器數據庫中了360后綴勒索病毒怎么辦?360后綴勒索病毒的加密形式

隨著信息技術的發展,企業的計算機服務器數據庫變得越來越重要。然而,在數字時代,網絡上的威脅也日益增多。近期,我們收到很多企業的求助,企業的計算機服務器遭到了360后綴勒索病毒的攻擊,導致服務器內的所有…

《TCP IP網絡編程》第二十四章

第 24 章 制作 HTTP 服務器端 24.1 HTTP 概要 本章將編寫 HTTP(HyperText Transfer Protocol,超文本傳輸協議)服務器端,即 Web 服務器端。 理解 Web 服務器端: web服務器端就是要基于 HTTP 協議,將網頁對…

easyx圖形庫基礎:3實現彈球小游戲

實現彈球小游戲 一.實現彈球小游戲:1.初始化布:2.初始化一個球的信息:3.球的移動和碰撞反彈4.底邊擋板的繪制和移動碰撞重置數據。 二.整體代碼: 一.實現彈球小游戲: 1.初始化布: int main() {initgraph(800, 600);setorigin(40…

[論文筆記]Glancing Transformer for Non-Autoregressive Neural Machine Translation

引言 這是論文Glancing Transformer for Non-Autoregressive Neural Machine Translation的筆記。 傳統的非自回歸文本生成速度較慢,因為需要給定之前的token來預測下一個token。但自回歸模型雖然效率高,但性能沒那么好。 這篇論文提出了Glancing Transformer,可以只需要一…

layui下拉框select 彈出層在最外層

出現問題如圖所示 想要的效果是如下 這樣的效果只需一行代碼就能解決 .layui-layer-page .layui-layer-content{overflow: visible!important;}

Postgresql源碼(112)plpgsql執行sql時變量何時替換為值

相關 《Postgresql源碼(41)plpgsql函數編譯執行流程分析》 《Postgresql源碼(46)plpgsql中的變量類型及對應關系》 《Postgresql源碼(49)plpgsql函數編譯執行流程分析總結》 《Postgresql源碼(5…

PyTorch從零開始實現ResNet

文章目錄 代碼實現參考 代碼實現 本文實現 ResNet原論文 Deep Residual Learning for Image Recognition 中的50層,101層和152層殘差連接。 代碼中使用基礎殘差塊這個概念,這里的基礎殘差塊指的是上圖中紅色矩形圈出的內容:從上到下分別使用…

感覺和身邊其他人有差距怎么辦?

雖然清楚知識需要靠時間沉淀,但在看到自己做不出來的題別人會做,自己寫不出的代碼別人會寫時還是會感到焦慮怎么辦? 你是否也因為自身跟周圍人的差距而產生過迷茫,這份迷茫如今是被你克服了還是仍舊讓你感到困擾? 下…

LabVIEW開發最小化5G系統測試平臺

LabVIEW開發最小化5G系統測試平臺 由于具有大量存儲能力和數據的應用程序的智能手機的激增,當前一代產品被迫提高其吞吐效率。正交頻分復用由于其卓越的品質,如單抽頭均衡和具有成本效益的實施,現在被廣泛用作物理層技術。這些好處是以嚴格的…

ElasticSearch索引庫、文檔、RestClient操作

文章目錄 一、索引庫1、mapping屬性2、索引庫的crud 二、文檔的crud三、RestClient 一、索引庫 es中的索引是指相同類型的文檔集合,即mysql中表的概念 映射:索引中文檔字段的約束,比如名稱、類型 1、mapping屬性 mapping映射是對索引庫中文…

Elasticsearch在部署時,對Linux的設置有哪些優化方法?

部署Elasticsearch時,可以通過優化Linux系統的設置來提升性能和穩定性。以下是一些常見的優化方法: 1.文件描述符限制 Elasticsearch需要大量的文件描述符來處理數據和連接,所以確保調整系統的文件描述符限制。可以通過修改 /etc/security/…

Docker-compose搭建Git私服

1. 新建個專用的目錄,然后在里面新建個docker-compose.yml文件: (gitlab-ce是社區版,當然還有ee,是商業版) version: 3.6 …

es自定義分詞器支持數字字母分詞,中文分詞器jieba支持添加禁用詞和擴展詞典

自定義分析器,分詞器 PUT http://xxx.xxx.xxx.xxx:9200/test_index/ {"settings": {"analysis": {"analyzer": {"char_test_analyzer": {"tokenizer": "char_test_tokenizer","filter": [&…

公網遠程連接Redis數據庫詳解

文章目錄 1. Linux(centos8)安裝redis數據庫2. 配置redis數據庫3. 內網穿透3.1 安裝cpolar內網穿透3.2 創建隧道映射本地端口 4. 配置固定TCP端口地址4.1 保留一個固定tcp地址4.2 配置固定TCP地址4.3 使用固定的tcp地址連接 前言 潔潔的個人主頁 我就問你有沒有發揮&#xff0…

ssh免密登陸報錯ERROR: @ WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!

問題描述: 在日常的運維中需要做ssh的免密登陸有提示如下的報錯內容: [rootpaas-harbor01 cce-v5.2.3]# ssh-copy-id 192.45.66.14 /usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub" /usr/bin/ssh-c…

通訊錄實現【C語言】

目錄 前言 一、整體邏輯分析 二、實現步驟 1、創建菜單和多次操作問題 2、創建通訊錄 3、初始化通訊錄 4、添加聯系人 5、顯示聯系人 6、刪除指定聯系人 ?7、查找指定聯系人 8、修改聯系人信息 9、排序聯系人信息 三、全部源碼 前言 我們上期已經詳細的介紹了自定…

Java SpringBoot Vue ERP系統

系統介紹 該ERP系統基于SpringBoot框架和SaaS模式,支持多租戶,專注進銷存財務生產功能。主要模塊有零售管理、采購管理、銷售管理、倉庫管理、財務管理、報表查詢、系統管理等。支持預付款、收入支出、倉庫調撥、組裝拆卸、訂單等特色功能。擁有商品庫存…

ubuntu設置共享文件夾成功后卻不顯示找不到(已解決)

1.首先輸下面命令查看是否真的設置成功共享文件夾 vmware-hgfsclient如果確實已經設置過共享文件夾將輸出window下共享文件夾名字 2.確認自己已設置共享文件夾后輸入下面的命令 //如果之前沒有命令包則先執行sudo apt-get install open-vm-tools sudo vmhgfs-fuse .host:/ /mn…

十六、Spring Cloud Sleuth 分布式請求鏈路追蹤

目錄 一、概述1、為什么出出現這個技術?需要解決哪些問題2、是什么?3、解決 二、搭建鏈路監控步驟1、下載運行zipkin2、服務提供者3、服務調用者4、測試 一、概述 1、為什么出出現這個技術?需要解決哪些問題 2、是什么? 官網&am…