精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何使用Rollup開發一個npm包并發布

開發 前端
由于我們公司項目不是采用 Monorepo 的方式去管理的,所以現階段比較好的辦法就是寫一個工具庫包,發布到私有 npm 倉庫上,然后在每一個項目中去安裝使用即可~ 這樣好處有!

背景

前幾天老大說現在團隊中很多冗余代碼,而其中一部分就表現在,很多項目都重復寫了一些一模一樣的工具函數,比如:

  • 公司內部加密函數
  • 公司內部的權限校驗函數
  • 公司內部的單點登錄封裝函數
  • 等等。。。。

其實這些函數在每一個項目中都是一模一樣的,沒必要每一個項目都寫一遍,這種做法有很多壞處

  • 代碼冗余
  • 不好維護,函數一改,就所有項目都需要一起改

由于我們公司項目不是采用 Monorepo 的方式去管理的,所以現階段比較好的辦法就是寫一個工具庫包,發布到私有 npm 倉庫上,然后在每一個項目中去安裝使用即可~ 這樣好處有

  • 減少了每個項目中的代碼冗余
  • 好維護,邏輯只需要改一處,然后改版本號重新發包即可

類比

在日常的開發中,我們會使用到很多很多的包,比如我們想要使用 lodash 只需要在終端里輸入

npm i lodash -D

然后我們就會在 node_modules中看到這個包,并且可以去使用它~

圖片圖片

import { cloneDeep } from 'lodash'

const obj1 = {};
const obj2 = cloneDeep(obj1)

這些包長啥樣?

我們打開 node_modules 中的 lodash 發現,里面其實都是打包后的產物,也就是開發 lodash 的開發者,編寫一些例如 ts、ES6 語法的代碼后,進行 打包后 發布到 npm 上,我們才可以通過 npm i lodash 去安裝它~

圖片圖片

那為啥要 打包后 才發布到 npm 上呢?這是因為

  • 需要把 ts、ES6 這些比較新語法轉換成 ES5 的舊語法
  • 需要對代碼進行壓縮后再發布,這樣體積會比較小一些

Webpack or Rollup?

大部分的前端開發者接觸到的打包工具都是 Webpack,而很少接觸到 Rollup,我可以給大家簡單講講這兩者有什么區別~

Webpack

Webpack主要用于構建復雜的前端項目。他能做以下這些事情:

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

由于 Webpack 的靈活性和豐富的功能,它適用于大型、復雜的項目,特別是那些包含大量模塊和資源、有復雜構建需求的項目

Rollup

Rollup是一個面向現代JavaScript應用的模塊打包工具,專注于創建用于庫和類似庫的打包。具備以下這些特點:

  • 采用ES模塊作為標準,可以按需引入和打包代碼,并且能夠進行 Tree Shaking,去除未使用的代碼,減小輸出文件大小
  • 相對于 Webpack,Rollup 更加輕量級和簡單,它不提供像Webpack那樣豐富的插件和加載器生態系統,但它的輸出更精簡

小結

  • Webpack 適合用在項目中
  • Rollup 適用于開發一些工具庫、組件庫

所以我們開發工具庫是推薦使用 Rollup 來開發

開發自己的工具庫

初始項目

首先新建一個 npm-sx-test 的文件夾,用來開發我們的工具庫

名字可以自己定~

然后進入到 npm-sx-test 中,運行

npm init

初始化一個 npm 的環境~

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

接著在根目錄下,創建一個入口文件 index.js 以及一個 utils 文件夾

  • index.js 用來統一導出所有工具函數
  • utils 用來存放各種工具函數

圖片圖片

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

export default {
  crypto,
  checkPermission,
  sso
}

配置 Rollup & Babel 打包環境

代碼寫完后,我們需要將他們打包,還記得我們上面說了為啥要打包后再發布?

  • 1、需要把 ts、ES6 這些比較新語法轉換成 ES5 的舊語法
  • 2、需要對代碼進行壓縮后再發布,這樣體積會比較小一些

我們需要先安裝這些必要的插件

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

接著創建一個 rollup.config.js 用來存放 Rollup 打包的配置

// rollup.config.js
import 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: {  // 配置監聽處理
    exclude: 'node_modules/**'
  },
  plugins: [
    // 使用插件 @rollup/plugin-babel
    babel({
      babelHelpers: 'bundled',
      exclude: 'node_modules/**'
    })
  ]
};

然后新建一個 babel.config.js 用來配置 Babel ,它可以幫我們把一些高級語法轉成低級語法

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

配置打包命令

現在我們可以配置打包命令了,在 package.json 中,配置命令

"scripts": {
    "build": "rollup -c",     
    "serve": "rollup -c -w"
  }
  • -c:代表讀取配置去打包,默認讀取根目錄下的babel.config.js
  • -w:代表了 watch 監聽,調試的時候可以用~

運行 npm run build 之后,我們可以看到打包成兩個版本

  • dist:產物是 Commonjs 模塊化
  • es:產物是 ES6 模塊化

圖片圖片

圖片圖片

發布 NPM 包

首先我們需要把 NPM 的源設置成你想要的,一般都是設置為公司的私有倉庫地址,但是這里我設置為公共倉庫~

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

接著我們需要登錄 NPM ,進行身份認證~

npm login

需要填寫這些信息

  • username:npm 的用戶名
  • password:npm 的密碼
  • email:npm 注冊的郵箱
  • one-time password:郵箱接收的驗證碼

圖片圖片

最后修改一下 package.json里

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

然后運行 npm publish,就會將打包后的產物推送到 npm 上了~

圖片圖片

使用函數庫

現在回到各個項目中,只需要

npm i npm-sx-test

就可以使用我們自己的組件庫啦~

import { checkPermission } from 'npm-sx-test'

console.log(checkPermission('admin'))

責任編輯:武曉燕 來源: 前端之神
相關推薦

2022-08-14 08:29:21

npmNode

2018-05-07 13:42:52

LinuxnpmNodeJS

2024-01-26 12:35:25

JavaScript項目軟件包

2021-11-12 07:00:46

tsdx開發環境

2023-09-08 08:10:48

2023-09-08 08:22:30

2021-09-03 12:33:36

語言并發下載器

2017-08-21 11:13:43

LinuxSnapcraft Snap軟件包

2022-02-16 20:36:30

瀏覽器PythonJavaScript

2018-06-19 16:04:27

Dubbo應用Java

2024-03-15 15:20:10

并發服務IP

2022-02-25 08:19:12

項目npm倉庫業務組件庫

2019-08-01 08:36:51

緩存系統并發

2022-01-05 08:58:08

Python解釋器編程語言

2014-03-12 10:00:26

移動開發跨平臺

2018-01-08 14:31:09

Electron桌面APP前端

2023-03-17 18:33:12

ChatGPTLLM應用

2015-03-10 11:21:44

JavaScript組JavaScript

2025-04-30 08:56:34

2025-09-29 04:55:00

高并發關單系統算法
點贊
收藏

51CTO技術棧公眾號

欧美日韩激情一区二区| 91美女片黄在线观看| 日韩中文第一页| 中文字幕在线播放一区二区| www在线观看黄色| 国产欧美视频在线观看| 91在线在线观看| 男人天堂2024| 欧美日韩亚洲一区三区| 日韩久久精品电影| 91欧美一区二区三区| 中文字幕在线直播| 樱花影视一区二区| 欧洲一区二区在线观看| 亚洲爱爱综合网| 巨乳诱惑日韩免费av| 九色精品美女在线| 日本一级免费视频| 国产66精品| 欧美久久久影院| 欧美a在线视频| 18网站在线观看| 国产欧美va欧美不卡在线| 国产精品一区二| 97精品久久人人爽人人爽| 国产一区导航| 欧美大片欧美激情性色a∨久久| 成人免费网站黄| 91精品尤物| 9191成人精品久久| 亚洲三级视频网站| 电影网一区二区| 亚洲午夜精品在线| 佐佐木明希av| 毛片在线看网站| 国产欧美视频一区二区三区| 久久草视频在线看| 少妇高潮一区二区三区99小说| 久久se精品一区精品二区| 日本一区二区不卡| 青青草成人av| 国产日韩一区二区三区在线| 欧美国产日韩视频| 黄色一级视频在线观看| 久久精品青草| 久久九九亚洲综合| 欧美激情图片小说| 国产精品久久久久久久免费观看| 在线a欧美视频| 妺妺窝人体色WWW精品| 蜜乳av综合| 亚洲女人天堂成人av在线| 国产精品久久久免费观看| 大奶一区二区三区| 亚洲成人网在线观看| 免费不卡的av| 精品国产午夜肉伦伦影院| 亚洲国产黄色片| 91视频在线免费| 欧美三级午夜理伦三级小说| 亚洲国产高潮在线观看| 欧美成人三级伦在线观看| 精品国产导航| 亚洲码在线观看| 亚洲欧美va天堂人熟伦| 欧美日中文字幕| 日韩有码在线电影| 丝袜 亚洲 另类 欧美 重口| 欧美片第1页综合| 欧美人交a欧美精品| 国产精品第二十页| 久久婷婷影院| 国产日本欧美一区二区三区| 国产绿帽刺激高潮对白| 国产激情一区二区三区四区| 国产精品v欧美精品∨日韩| 色婷婷av一区二区三| 26uuu亚洲| 亚洲高清资源综合久久精品| 日本美女高清在线观看免费| 一区二区三区国产豹纹内裤在线| 激情小视频网站| 日韩成人动漫| 7777女厕盗摄久久久| 制服丝袜在线第一页| 亚洲欧美tv| 久久精品人人做人人爽| 国产一级淫片a| 久久一区二区三区四区五区 | 丝袜美腿亚洲综合| 国产精品视频区1| 国产成人精品亚洲精品色欲| 99国产精品国产精品久久| 日韩欧美一区二区在线观看| 黄av在线免费观看| 欧美日韩精品中文字幕| 亚洲一级片网站| 超碰97久久| 亚洲最新av在线网站| 国产a免费视频| 天堂va蜜桃一区二区三区| 成人性生交大片免费观看嘿嘿视频| 日本xxxx人| 国产精品超碰97尤物18| 少妇av一区二区三区无码| 日韩综合久久| 亚洲人精品午夜在线观看| 国产又黄又爽又无遮挡| 日韩精品欧美精品| 国产一区视频观看| 精产国品自在线www| 日韩欧美在线播放| 成人啪啪18免费游戏链接| 欧美一区电影| **欧美日韩vr在线| 精品人妻无码一区二区三区蜜桃一| 久久久久久久久久久黄色| 青青草视频在线视频| 国产69精品久久| 国产婷婷色综合av蜜臀av| 青娱乐国产在线| 久久成人久久鬼色| 日本一区二区三区免费观看| 国产h片在线观看| 欧美一级午夜免费电影| 中文字幕在线观看免费高清 | 99视频精品免费| 国产成人一二片| 欧美不卡视频一区发布| 中文字幕免费播放| 国产亚洲欧美中文| 精品少妇人妻av免费久久洗澡| 一区二区三区影院| 91精品国产91久久久| 国产又粗又猛又黄| 久久久久国产成人精品亚洲午夜| 亚洲理论电影在线观看| www久久久| 色偷偷9999www| 69xxxx国产| 国产亚洲欧洲一区高清在线观看| a√天堂在线观看| 果冻天美麻豆一区二区国产| 欧美国产日韩一区| 丰满人妻一区二区| 亚洲一线二线三线视频| 国产在线观看免费播放| 欧美日韩国产高清| 福利视频一区二区三区| 羞羞网站在线看| 日韩久久精品一区| 久草资源在线视频| 成人动漫一区二区在线| 欧美午夜小视频| 久久a级毛片毛片免费观看| 国模精品视频一区二区三区| 国产91久久久| 午夜激情一区二区| 亚洲一区二区观看| 视频在线观看一区| 亚洲一区二区三区精品动漫| 99久久亚洲国产日韩美女| 自拍亚洲一区欧美另类| 91亚洲国产成人精品一区| 最新国产成人在线观看| 性生交大片免费看l| 亚洲福利免费| 欧美在线播放一区| 亚洲伦理一区二区| 欧美国产日韩中文字幕在线| 污视频在线免费观看| 色婷婷国产精品久久包臀| 中文字幕有码在线播放| 激情综合色播五月| 国产一区二区三区乱码| 天堂俺去俺来也www久久婷婷 | 日韩三级视频在线观看| 国产一级视频在线| 久久久99精品免费观看不卡| aaa一级黄色片| 日韩午夜高潮| 污视频在线免费观看一区二区三区| 91丨精品丨国产| 久久久久国产精品一区| 精品成人一区二区三区免费视频| 欧美日韩国产综合一区二区三区| 免费一级片视频| 久久久www成人免费无遮挡大片| 亚洲一区日韩精品| 亚洲精品三级| 亚洲精品无人区| 精品国产午夜肉伦伦影院| 国产精品丝袜视频| 视频在线这里都是精品| 亚洲人成在线观看网站高清| 国产浮力第一页| 日本久久一区二区| 久草网视频在线观看| 国产精品日产欧美久久久久| 日批免费观看视频| 蜜臂av日日欢夜夜爽一区| 亚洲一区二区三区av无码| 欧美码中文字幕在线| 国产精品二区三区| 九九久久国产| 欧美中文字幕第一页| 色呦呦在线视频| 在线一区二区日韩| 手机亚洲第一页| 欧美一区二区在线看| 无码视频在线观看| 午夜精品久久久久影视| 午夜爽爽爽男女免费观看| 久久久www成人免费无遮挡大片| 可以看的av网址| 久久99精品一区二区三区三区| aa在线观看视频| 欧美另类女人| 一区二区三区不卡在线| 伊甸园亚洲一区| 精品蜜桃一区二区三区| 日韩精品免费视频一区二区三区| 国产精品你懂得| 天天综合网站| 91sao在线观看国产| 福利小视频在线| 九九久久国产精品| 黄色网址免费在线观看| 色婷婷成人综合| 福利小视频在线观看| 精品视频久久久久久| 日本黄色大片视频| 欧美电视剧在线看免费| 国产丝袜视频在线观看| 欧美精品久久99久久在免费线 | 欧美一区二区三区喷汁尤物| 亚洲一区二区视频在线播放| 日本精品视频一区二区三区| 日本特级黄色片| 欧美日韩一区二区精品| 中文字幕亚洲精品在线| 欧美日韩国产精品一区二区三区四区 | 国产精品热久久久久夜色精品三区 | 亚洲综合成人av| 色老头久久综合| 国产婷婷色一区二区在线观看| 亚洲国产精品人人做人人爽| 国产精品成人国产乱| 亚洲大片精品永久免费| 日韩精品一区二区三区国语自制| 同产精品九九九| av大片免费观看| 欧美午夜xxx| 亚洲成人av网址| 精品视频资源站| 99riav国产| 亚洲电影免费观看高清| 先锋av资源站| 亚洲人成网站777色婷婷| 成人精品一区二区三区免费| 日韩一区视频在线| 欧美xxxbbb| 97成人精品区在线播放| 暖暖成人免费视频| 国产在线精品播放| gogo人体一区| 欧美不卡三区| 俺要去色综合狠狠| 在线观看三级网站| 亚洲乱码视频| 国产视频在线视频| 国产精品18久久久| 熟女人妻在线视频| 中文一区二区在线观看| 粉嫩av性色av蜜臀av网站| 亚洲电影在线免费观看| 老熟妇仑乱一区二区av| 欧美日韩视频在线一区二区| 精品国产av鲁一鲁一区| 亚洲激情在线观看视频免费| 东凛在线观看| 色综合男人天堂| 最新日韩精品| 亚洲一区二区三区在线视频| 狼人精品一区二区三区在线| 丝袜美腿玉足3d专区一区| 一个色综合网| 女性隐私黄www网站视频| 国产最新精品免费| 艳妇乳肉亭妇荡乳av| 国产精品三级视频| 久久草视频在线| 欧美日韩亚洲国产综合| 天堂网av在线播放| 久久精品国产精品亚洲| 日韩伦理在线一区| 亚洲在线视频福利| 欧美日韩伦理在线免费| 欧美不卡在线播放| 国产在线精品免费| 亚洲av无码一区二区三区人| 亚洲综合色自拍一区| 精品国产www| 日韩精品电影网| 日本在线视频中文有码| 国产精品久久久久影院日本| 久久97精品| 97在线免费视频观看| 美女视频网站黄色亚洲| 久久久久9999| 亚洲午夜久久久久久久久久久| 91欧美日韩麻豆精品| 亚洲最大中文字幕| 韩日精品一区二区| 狠狠色综合色区| 欧美激情无毛| 在线免费黄色小视频| 国产精品无码永久免费888| 亚洲黄色免费观看| 亚洲第一页自拍| 国产黄色大片在线观看| 91视频网页| 亚洲乱码电影| 久久久久久久久久一区二区| 国产婷婷色一区二区三区四区| 午夜毛片在线观看| 亚洲国产精品久久久久| 欧美videos另类精品| 亚洲综合av影视| 亚洲一区色图| 亚洲第一区第二区第三区| 国产精品久久久久久久久免费桃花| 影音先锋在线国产| 国产视频精品在线| 日产福利视频在线观看| 精品国产乱码久久久久久108| 国产精品hd| 一级黄色片毛片| 亚洲午夜精品在线| 色婷婷av一区二区三| 午夜精品蜜臀一区二区三区免费| 哺乳挤奶一区二区三区免费看| 国产成人免费高清视频| 国产精品一区二区久久不卡| 午夜爱爱毛片xxxx视频免费看| 6080日韩午夜伦伦午夜伦| 日本精品在线| 91精品国产一区二区三区动漫| 亚洲电影影音先锋| www.偷拍.com| 亚洲中国最大av网站| 人妻精品一区二区三区| 91国产美女视频| 杨幂一区二区三区免费看视频| 精品一卡二卡三卡| 国产精品三级av| 国产乱淫av免费| 九九九久久久久久| 五月天亚洲一区| 男女爽爽爽视频| 亚洲视频一区二区免费在线观看| 国产精品一区二区黑人巨大| 久久99精品国产99久久6尤物| 国产+成+人+亚洲欧洲在线| www一区二区www免费| 国产亚洲精品bt天堂精选| 亚洲无码久久久久| 欧美精品久久久久| 免费精品国产的网站免费观看| 亚洲国产精品三区| 亚洲人成小说网站色在线| 亚洲福利在线观看视频| 琪琪第一精品导航| 欧美成人激情| zjzjzjzjzj亚洲女人| 色哟哟精品一区| 国产在线激情| 精品视频第一区| 久久国产免费看| 国产精品suv一区二区| 亚洲美女在线观看| 国产精品视频一区二区三区综合| 欧美一级视频免费看| 中文字幕av不卡| 丰满肥臀噗嗤啊x99av| 日本在线观看天堂男亚洲| 91精品啪在线观看国产81旧版| 97人妻精品一区二区三区免费| 欧美综合色免费| 国产亚av手机在线观看| 视频在线一区二区三区| 国产成人av资源| 中国女人真人一级毛片| 欧美激情一区二区三区久久久 | 亚洲品质视频自拍网| 亚洲伊人精品酒店| 国产美女三级视频| 一区二区在线观看视频| 懂色av中文在线| 久久国产精品-国产精品|