日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當(dāng)前位置:首頁 > 科技  > 軟件

如何使用Rollup開發(fā)一個(gè)npm包并發(fā)布

來源: 責(zé)編: 時(shí)間:2024-05-09 17:56:25 224觀看
導(dǎo)讀背景前幾天老大說現(xiàn)在團(tuán)隊(duì)中很多冗余代碼,而其中一部分就表現(xiàn)在,很多項(xiàng)目都重復(fù)寫了一些一模一樣的工具函數(shù),比如:公司內(nèi)部加密函數(shù)公司內(nèi)部的權(quán)限校驗(yàn)函數(shù)公司內(nèi)部的單點(diǎn)登錄封裝函數(shù)等等。。。。其實(shí)這些函數(shù)在每一個(gè)項(xiàng)

背景

前幾天老大說現(xiàn)在團(tuán)隊(duì)中很多冗余代碼,而其中一部分就表現(xiàn)在,很多項(xiàng)目都重復(fù)寫了一些一模一樣的工具函數(shù),比如:4zu28資訊網(wǎng)——每日最新資訊28at.com

  • 公司內(nèi)部加密函數(shù)
  • 公司內(nèi)部的權(quán)限校驗(yàn)函數(shù)
  • 公司內(nèi)部的單點(diǎn)登錄封裝函數(shù)
  • 等等。。。。

其實(shí)這些函數(shù)在每一個(gè)項(xiàng)目中都是一模一樣的,沒必要每一個(gè)項(xiàng)目都寫一遍,這種做法有很多壞處4zu28資訊網(wǎng)——每日最新資訊28at.com

  • 代碼冗余
  • 不好維護(hù),函數(shù)一改,就所有項(xiàng)目都需要一起改

由于我們公司項(xiàng)目不是采用 Monorepo 的方式去管理的,所以現(xiàn)階段比較好的辦法就是寫一個(gè)工具庫包,發(fā)布到私有 npm 倉庫上,然后在每一個(gè)項(xiàng)目中去安裝使用即可~ 這樣好處有4zu28資訊網(wǎng)——每日最新資訊28at.com

  • 減少了每個(gè)項(xiàng)目中的代碼冗余
  • 好維護(hù),邏輯只需要改一處,然后改版本號(hào)重新發(fā)包即可

類比

在日常的開發(fā)中,我們會(huì)使用到很多很多的包,比如我們想要使用 lodash 只需要在終端里輸入4zu28資訊網(wǎng)——每日最新資訊28at.com

npm i lodash -D

然后我們就會(huì)在 node_modules中看到這個(gè)包,并且可以去使用它~4zu28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片4zu28資訊網(wǎng)——每日最新資訊28at.com

import { cloneDeep } from 'lodash'const obj1 = {};const obj2 = cloneDeep(obj1)

這些包長(zhǎng)啥樣?

我們打開 node_modules 中的 lodash 發(fā)現(xiàn),里面其實(shí)都是打包后的產(chǎn)物,也就是開發(fā) lodash 的開發(fā)者,編寫一些例如 ts、ES6 語法的代碼后,進(jìn)行 打包后 發(fā)布到 npm 上,我們才可以通過 npm i lodash 去安裝它~4zu28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片4zu28資訊網(wǎng)——每日最新資訊28at.com

那為啥要 打包后 才發(fā)布到 npm 上呢?這是因?yàn)?span style="display:none">4zu28資訊網(wǎng)——每日最新資訊28at.com

  • 需要把 ts、ES6 這些比較新語法轉(zhuǎn)換成 ES5 的舊語法
  • 需要對(duì)代碼進(jìn)行壓縮后再發(fā)布,這樣體積會(huì)比較小一些

Webpack or Rollup?

大部分的前端開發(fā)者接觸到的打包工具都是 Webpack,而很少接觸到 Rollup,我可以給大家簡(jiǎn)單講講這兩者有什么區(qū)別~4zu28資訊網(wǎng)——每日最新資訊28at.com

Webpack

Webpack主要用于構(gòu)建復(fù)雜的前端項(xiàng)目。他能做以下這些事情:4zu28資訊網(wǎng)——每日最新資訊28at.com

  • 支持將多種資源(如JavaScript、CSS、圖片等)視為模塊,并通過模塊依賴關(guān)系進(jìn)行打包
  • 提供了豐富的插件和加載器,能夠處理各種復(fù)雜的場(chǎng)景,如代碼分割、懶加載、熱模塊替換等
  • 它還支持開發(fā)環(huán)境和生產(chǎn)環(huán)境的不同配置,使得項(xiàng)目開發(fā)和部署更加方便

由于 Webpack 的靈活性和豐富的功能,它適用于大型、復(fù)雜的項(xiàng)目,特別是那些包含大量模塊和資源、有復(fù)雜構(gòu)建需求的項(xiàng)目4zu28資訊網(wǎng)——每日最新資訊28at.com

Rollup

Rollup是一個(gè)面向現(xiàn)代JavaScript應(yīng)用的模塊打包工具,專注于創(chuàng)建用于庫和類似庫的打包。具備以下這些特點(diǎn):4zu28資訊網(wǎng)——每日最新資訊28at.com

  • 采用ES模塊作為標(biāo)準(zhǔn),可以按需引入和打包代碼,并且能夠進(jìn)行 Tree Shaking,去除未使用的代碼,減小輸出文件大小
  • 相對(duì)于 Webpack,Rollup 更加輕量級(jí)和簡(jiǎn)單,它不提供像Webpack那樣豐富的插件和加載器生態(tài)系統(tǒng),但它的輸出更精簡(jiǎn)

小結(jié)

  • Webpack 適合用在項(xiàng)目中
  • Rollup 適用于開發(fā)一些工具庫、組件庫

所以我們開發(fā)工具庫是推薦使用 Rollup 來開發(fā)4zu28資訊網(wǎng)——每日最新資訊28at.com

開發(fā)自己的工具庫

初始項(xiàng)目

首先新建一個(gè) npm-sx-test 的文件夾,用來開發(fā)我們的工具庫4zu28資訊網(wǎng)——每日最新資訊28at.com

名字可以自己定~4zu28資訊網(wǎng)——每日最新資訊28at.com

然后進(jìn)入到 npm-sx-test 中,運(yùn)行4zu28資訊網(wǎng)——每日最新資訊28at.com

npm init

初始化一個(gè) npm 的環(huán)境~4zu28資訊網(wǎng)——每日最新資訊28at.com

{     name: 'npm-sx-test', // 包名     main: 'index.js', // 包被引入時(shí)的入口文件     type: "module", // 代碼可以使用 ES6 模塊化    version: 1.0.0, // 版本     description: '', // 描述     author: 'zh', // 作者     contributors: '', // 其他貢獻(xiàn)者     dependencies: {}, // 生產(chǎn)依賴     devDependencies: {}, // 開發(fā)依賴     repository:'', // 源碼地址     keywords: [], // 包搜索關(guān)鍵字  }

接著在根目錄下,創(chuàng)建一個(gè)入口文件 index.js 以及一個(gè) utils 文件夾4zu28資訊網(wǎng)——每日最新資訊28at.com

  • index.js 用來統(tǒng)一導(dǎo)出所有工具函數(shù)
  • utils 用來存放各種工具函數(shù)

圖片圖片4zu28資訊網(wǎng)——每日最新資訊28at.com

// permission.jsexport const checkPermission = (role) => {  // coding...  return role}// crypto.jsexport const crypto = (password) => {  // coding...  return password}// sso.jsexport const sso = (username) => {  // coding...  return username}// index.jsimport { crypto } from './utils/crypto'import { checkPermission } from './utils/permission'import { sso } from './utils/sso'export default {  crypto,  checkPermission,  sso}

配置 Rollup & Babel 打包環(huán)境

代碼寫完后,我們需要將他們打包,還記得我們上面說了為啥要打包后再發(fā)布?4zu28資訊網(wǎng)——每日最新資訊28at.com

  • 1、需要把 ts、ES6 這些比較新語法轉(zhuǎn)換成 ES5 的舊語法
  • 2、需要對(duì)代碼進(jìn)行壓縮后再發(fā)布,這樣體積會(huì)比較小一些

我們需要先安裝這些必要的插件4zu28資訊網(wǎng)——每日最新資訊28at.com

npm i @babel/preset-env      @rollup/plugin-babel      rollup

接著創(chuàng)建一個(gè) rollup.config.js 用來存放 Rollup 打包的配置4zu28資訊網(wǎng)——每日最新資訊28at.com

// rollup.config.jsimport babel from '@rollup/plugin-babel';export default {   input: 'index.js', // 入口文件  output: [    {      file: './es/index.js',      format: 'esm',  // 將軟件包保存為 ES 模塊文件      name: 'cssModuleVue'    },    {      file: './dist/index.js',      format: 'cjs',  // CommonJS,適用于 Node 和 Browserify/Webpack      name: 'cssModuleVue',      exports: 'default'    }  ],  watch: {  // 配置監(jiān)聽處理    exclude: 'node_modules/**'  },  plugins: [    // 使用插件 @rollup/plugin-babel    babel({      babelHelpers: 'bundled',      exclude: 'node_modules/**'    })  ]};

然后新建一個(gè) babel.config.js 用來配置 Babel ,它可以幫我們把一些高級(jí)語法轉(zhuǎn)成低級(jí)語法4zu28資訊網(wǎng)——每日最新資訊28at.com

// babel.config.js{  "presets": [    [      "@babel/preset-env",      {        "modules": false      }    ]  ]}

配置打包命令

現(xiàn)在我們可以配置打包命令了,在 package.json 中,配置命令4zu28資訊網(wǎng)——每日最新資訊28at.com

"scripts": {    "build": "rollup -c",         "serve": "rollup -c -w"  }
  • -c:代表讀取配置去打包,默認(rèn)讀取根目錄下的babel.config.js
  • -w:代表了 watch 監(jiān)聽,調(diào)試的時(shí)候可以用~

運(yùn)行 npm run build 之后,我們可以看到打包成兩個(gè)版本4zu28資訊網(wǎng)——每日最新資訊28at.com

  • dist:產(chǎn)物是 Commonjs 模塊化
  • es:產(chǎn)物是 ES6 模塊化

圖片圖片4zu28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片4zu28資訊網(wǎng)——每日最新資訊28at.com

發(fā)布 NPM 包

首先我們需要把 NPM 的源設(shè)置成你想要的,一般都是設(shè)置為公司的私有倉庫地址,但是這里我設(shè)置為公共倉庫~4zu28資訊網(wǎng)——每日最新資訊28at.com

npm config set registry https://registry.npmjs.org/

接著我們需要登錄 NPM ,進(jìn)行身份認(rèn)證~4zu28資訊網(wǎng)——每日最新資訊28at.com

npm login

需要填寫這些信息4zu28資訊網(wǎng)——每日最新資訊28at.com

  • username:npm 的用戶名
  • password:npm 的密碼
  • email:npm 注冊(cè)的郵箱
  • one-time password:郵箱接收的驗(yàn)證碼

圖片圖片4zu28資訊網(wǎng)——每日最新資訊28at.com

最后修改一下 package.json里4zu28資訊網(wǎng)——每日最新資訊28at.com

加上 "main": "dist/index.js", 加上 "module": "es/index.js"  加上 "files": [    "es/*",    "dist/*"  ],
  • 修改 main 是為了我們使用這個(gè)包時(shí)引用到 dist 里的文件
  • 修改 files 是為了推送 npm 只推送所需要的文件上去就行

然后運(yùn)行 npm publish,就會(huì)將打包后的產(chǎn)物推送到 npm 上了~4zu28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片4zu28資訊網(wǎng)——每日最新資訊28at.com

使用函數(shù)庫

現(xiàn)在回到各個(gè)項(xiàng)目中,只需要4zu28資訊網(wǎng)——每日最新資訊28at.com

npm i npm-sx-test

就可以使用我們自己的組件庫啦~4zu28資訊網(wǎng)——每日最新資訊28at.com

import { checkPermission } from 'npm-sx-test'console.log(checkPermission('admin'))

4zu28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-87679-0.html如何使用Rollup開發(fā)一個(gè)npm包并發(fā)布

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。郵件:2376512515@qq.com

上一篇: Container包中的那些容器,你知道幾個(gè)?

下一篇: 一篇聊透云原生中的服務(wù)網(wǎng)格

標(biāo)簽:
  • 熱門焦點(diǎn)
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
久久综合一区二区| 久久精品国产一区二区三区| 亚洲精品网址在线观看| 99天天综合性| 午夜亚洲精品| 久久尤物视频| 欧美日本亚洲韩国国产| 国产精品美女一区二区| 激情久久久久久久久久久久久久久久| 亚洲二区视频| 亚洲一区视频在线观看视频| 久久精品视频免费| 欧美日韩国产色综合一二三四| 国产精品五区| 蜜桃久久av| 欧美日韩国产在线一区| 国产一区二区精品丝袜| 亚洲精品美女免费| 性做久久久久久免费观看欧美| 毛片基地黄久久久久久天堂| 国产精品草莓在线免费观看| 一区二区在线观看视频| 99在线|亚洲一区二区| 久久久国产精品一区二区中文| 欧美一区二区三区婷婷月色| 美日韩精品视频免费看| 国产精品高潮粉嫩av| 在线欧美日韩国产| 午夜国产欧美理论在线播放| 欧美寡妇偷汉性猛交| 国产亚洲成人一区| 一区二区三欧美| 狼狼综合久久久久综合网| 国产精品美女久久久免费| 亚洲国产天堂网精品网站| 欧美一区二区三区四区在线观看地址| 欧美日韩精品免费观看视频| 欧美亚洲尤物久久| 欧美视频一区二区三区…| 亚洲国产一区二区精品专区| 性欧美激情精品| 欧美三级视频在线播放| 亚洲高清电影| 欧美一区二区女人| 欧美午夜精品理论片a级按摩| 亚洲第一精品夜夜躁人人爽 | 狠狠色狠色综合曰曰| 亚洲一级片在线观看| 欧美精品一区视频| 在线观看亚洲一区| 欧美专区在线| 国产精品日韩电影| 宅男精品视频| 欧美精品在线视频| 亚洲国产精品传媒在线观看| 久久免费黄色| 国产综合久久久久影院| 午夜精品久久久久久久99水蜜桃| 欧美日韩在线视频首页| 亚洲精品影视| 欧美激情视频在线免费观看 欧美视频免费一 | 久久久久久一区二区| 国产精品嫩草久久久久| 一本色道久久综合亚洲精品婷婷| 欧美福利一区二区| 亚洲国产欧美一区二区三区同亚洲| 久久精品人人做人人爽电影蜜月| 国产精品视频不卡| 亚洲欧美在线x视频| 国产精品乱码久久久久久| 中文在线不卡视频| 欧美视频四区| 亚洲天堂网在线观看| 国产精品国色综合久久| 亚洲免费在线| 裸体一区二区三区| 国产一区二区三区在线观看视频 | 欧美一区二区三区在线看| 国产精品网红福利| 欧美一区二区三区在| 国一区二区在线观看| 久久免费视频网| 亚洲国产成人久久| 欧美福利电影网| 亚洲狼人综合| 欧美视频导航| 亚洲欧美日韩国产综合精品二区| 国产欧美一区二区三区久久| 欧美在线观看天堂一区二区三区| 国产午夜精品全部视频播放| 久久精品亚洲精品| 亚洲成色www久久网站| 欧美大香线蕉线伊人久久国产精品| 亚洲人成免费| 欧美日韩亚洲一区二区三区| 亚洲一区二区欧美| 国产伦精品一区二区三区四区免费 | 国产精品爱久久久久久久| 亚洲一级电影| 国产午夜精品视频| 在线成人激情黄色| 欧美激情视频在线播放 | 久久一区国产| 亚洲人成绝费网站色www| 欧美日产国产成人免费图片| 亚洲一区二区精品在线观看| 国产日产高清欧美一区二区三区| 久久久久久尹人网香蕉| 亚洲精品乱码久久久久久日本蜜臀 | 亚洲精一区二区三区| 欧美日韩一区二区免费在线观看| 亚洲淫性视频| 狠狠干综合网| 欧美日本亚洲韩国国产| 亚洲欧美日本国产有色| 一区二区在线视频播放| 欧美日韩成人综合| 欧美一区二区三区免费观看 | 亚洲自拍电影| 黄色成人在线网址| 欧美日韩国产另类不卡| 香蕉久久夜色精品国产使用方法 | 久久久一二三| 日韩一区二区久久| 国产欧美一区二区三区国产幕精品| 玖玖玖国产精品| 亚洲视频高清| 亚洲成色777777女色窝| 国产精品v欧美精品v日韩精品| 久久久av毛片精品| 日韩视频一区二区在线观看| 国产麻豆一精品一av一免费| 蜜乳av另类精品一区二区| 亚洲一区亚洲二区| 亚洲国产裸拍裸体视频在线观看乱了| 欧美亚州一区二区三区| 久久日韩粉嫩一区二区三区| 亚洲深夜激情| 在线日本欧美| 国产精品美女一区二区| 欧美a级片网| 欧美一区二区日韩一区二区| 亚洲伦伦在线| 激情小说另类小说亚洲欧美| 国产精品video| 欧美sm重口味系列视频在线观看| 亚洲欧美视频一区二区三区| 亚洲人www| 国语自产精品视频在线看8查询8| 欧美色欧美亚洲另类二区| 久热精品视频在线观看| 亚洲欧美日韩爽爽影院| 亚洲精品视频一区二区三区| 一区二区三区在线不卡| 国产精品私拍pans大尺度在线| 欧美精品免费在线| 久久综合久久久| 欧美一区国产在线| 亚洲亚洲精品在线观看 | 久久久一区二区| 亚洲欧美日韩在线播放| 99热这里只有精品8| 亚洲国产另类精品专区| 国产在线乱码一区二区三区| 国产精品嫩草影院av蜜臀| 欧美日韩精品免费看 | 激情综合亚洲| 国产麻豆日韩欧美久久| 欧美性一二三区| 欧美极品aⅴ影院| 蜜桃精品久久久久久久免费影院| 欧美呦呦网站| 亚洲综合不卡| 一区二区日韩精品| 亚洲麻豆一区| 亚洲欧洲日产国码二区| 尤物精品国产第一福利三区| 国产一区二区三区av电影 | 亚洲一区二区三区国产| 亚洲精选一区| 最新国产成人在线观看| 在线观看日韩专区| 狠狠色综合网站久久久久久久| 国产日韩一区在线| 国产欧美一区二区精品性色| 国产欧美日韩一区| 国产麻豆91精品| 国产精品亚洲成人| 国产精品美女久久久久久免费| 欧美性猛片xxxx免费看久爱| 欧美日韩中文| 欧美日韩一级大片网址| 欧美日韩午夜| 欧美日韩一卡| 欧美系列电影免费观看| 国产精品xxx在线观看www| 欧美手机在线| 国产精品magnet| 国产精品jvid在线观看蜜臀| 欧美性猛交视频| 国产精品免费看久久久香蕉| 国产精品你懂的在线欣赏| 国产精品一区二区你懂得| 国产美女一区二区|