精品欧美一区二区三区在线观看 _久久久久国色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精品福利在线一区二区三区| 成人午夜视频网站| 中国china体内裑精亚洲片| 国产一区二区在线免费播放| 男人天堂网在线观看| 日精品一区二区三区| 超在线视频97| 日韩人妻无码一区二区三区| 欧美黄色网络| 亚洲一区免费在线观看| 亚洲欧美精品中文字幕在线| 国产av人人夜夜澡人人爽| 成年人在线观看网站| 国产.欧美.日韩| 国产精品久久久久久久久久久久| 妺妺窝人体色www聚色窝仙踪| 超碰成人免费| 欧美日韩成人高清| 国产二区视频在线播放| 国产美女av在线| 久久久午夜精品理论片中文字幕| 国产精品国产自产拍高清av水多| 久久精品国产亚洲av无码娇色 | 久久99久久99精品免费看小说| 成人搞黄视频| 欧美群妇大交群中文字幕| 精品久久一二三| 在线观看操人| 国产精品福利在线播放| 鲁片一区二区三区| 成人乱码一区二区三区| 韩国成人在线视频| 国产精品白丝jk喷水视频一区 | 黄色亚洲精品| 久久久精品久久| 公肉吊粗大爽色翁浪妇视频| 青青久久av| 精品对白一区国产伦| 久久精品亚洲天堂| 精品自拍视频| 欧美色图天堂网| 日韩精品免费播放| 在线观看涩涩| 精品美女久久久久久免费| 久久这里只有精品18| 理论片午午伦夜理片在线播放| 国产亚洲欧美一级| 欧美性天天影院| 视频午夜在线| 91污在线观看| 蜜桃麻豆www久久国产精品| 熟妇高潮一区二区三区| 成人avav影音| 国语精品免费视频| 天堂在线观看av| av一区二区三区四区| 国产亚洲第一区| 污视频在线免费| 99精品热视频| 欧美日韩亚洲在线| 黄色在线观看网| 国产精品美女一区二区三区| 亚洲欧美成人一区| 国产原厂视频在线观看| 亚洲精品高清视频在线观看| 成年人深夜视频| 99久久精品免费看国产小宝寻花 | 国产精品入口芒果| 操人在线观看| 日本丰满少妇一区二区三区| 欧美精品无码一区二区三区| 国产精品传媒麻豆hd| 欧美精品v日韩精品v韩国精品v| 污污的网站免费| 久久久久毛片免费观看| 精品动漫一区二区三区在线观看| 在线精品一区二区三区| 久久不见久久见免费视频7| 国产亚洲欧洲在线| 日韩一级片av| 在线亚洲伦理| 国产精品亚洲网站| www.国产麻豆| 26uuu久久综合| 性欧美.com| 欧美寡妇性猛交xxx免费| 午夜视频一区二区| 嫩草av久久伊人妇女超级a| 日韩三级影视| 日韩一级黄色片| 成人免费毛片日本片视频| 成人在线免费小视频| 久热精品视频在线| 国产精品人人人人| 国产一区视频在线看| 国产99在线播放| jzzjzzjzz亚洲成熟少妇| 樱花影视一区二区| 欧洲av无码放荡人妇网站| 天堂综合在线播放| 亚洲国产美女久久久久| 天堂а√在线中文在线鲁大师| 欧美日韩国产欧| 国产精品高清在线观看| 国产av一区二区三区精品| 久久五月婷婷丁香社区| 一级特黄妇女高潮| 日韩一区二区三区免费| 精品免费视频.| 色撸撸在线视频| 一本色道久久综合亚洲精品不卡 | 992tv在线成人免费观看| 中文字幕+乱码+中文字幕明步| 国产成人三级在线观看| 亚洲国产高清国产精品| 老色鬼在线视频| 欧美一卡在线观看| 成人无码av片在线观看| 好吊视频一区二区三区四区| 91精品久久久久久| 久久久久久女乱国产| 亚洲国产成人tv| 天堂av.com| 日韩夫妻性生活xx| 日本aⅴ大伊香蕉精品视频| 亚洲老妇色熟女老太| 中文字幕一区在线观看视频| 男人天堂成人在线| 黄色欧美在线| 久久999免费视频| 国产精品久久久久久免费免熟| 久久久久久久久久久电影| 精品无码一区二区三区爱欲| 日韩视频在线直播| 久久色在线播放| 亚洲综合网av| 国产精品人成在线观看免费| 国产成人久久777777| 久久久亚洲欧洲日产| 久久久999国产| 国产又粗又猛又爽| 国产精品久久免费看| 一区二区三区 日韩| 激情五月综合网| 国产精品第3页| 第一福利在线| 欧美视频在线观看一区| 男人的天堂官网 | 91精品视频国产| 在线观看日韩| 91免费在线观看网站| 最新国产在线拍揄自揄视频| 欧美一区二区三区视频免费| 波多野结衣在线网址| 国产最新精品精品你懂的| 亚洲国产精品女人| 久久伊人久久| 久久久亚洲影院你懂的| 天天操天天干天天操| 精品国产999| 在线免费观看麻豆| 奇米777欧美一区二区| 亚洲欧美日韩国产成人综合一二三区| 国产精品99精品一区二区三区∴| 久久午夜a级毛片| www日本视频| 午夜av一区二区三区| 亚洲 小说 欧美 激情 另类| 日韩主播视频在线| 在线观看精品视频| 日本在线一区二区三区| 欧美高清性猛交| 头脑特工队2免费完整版在线观看| 欧美午夜无遮挡| 正在播放国产对白害羞| 国产真实乱对白精彩久久| r级无码视频在线观看| 国产一区二区三区天码| 国产一区在线播放| a级片在线免费| 一区二区在线免费视频| aaa一区二区三区| 五月婷婷激情综合| 中文天堂资源在线| 国产成人精品三级| 黄色一级片播放| 久久精品影视| 免费不卡亚洲欧美| 国产成人免费av一区二区午夜 | 欧美91在线|欧美| 欧美高清视频在线| 男人天堂手机在线视频| 超黄网站在线观看| 亚洲人在线观看| www.色播.com| 欧美中文字幕亚洲一区二区va在线| 91麻豆免费视频网站| 99久久伊人网影院| 成人不卡免费视频| 一区二区日韩免费看| 亚洲在线不卡| 外国成人在线视频| 91九色视频在线观看| 午夜精品久久久久久久久久蜜桃| 久久国产色av| 成人在线播放视频| 亚洲国模精品一区| 国产精品视频无码| 在线精品国精品国产尤物884a| 精品在线免费观看视频| 国产精品久久久久天堂| 波多野结衣福利| 粉嫩av一区二区三区在线播放| 欧美日韩在线观看不卡| 亚洲女同在线| 欧妇女乱妇女乱视频| 欧美韩国日本在线观看| 日本精品一区二区| 欧美变态挠脚心| 99re视频在线播放| 在线播放成人| 国产精品午夜一区二区欲梦| 免费看av不卡| 国产69精品久久久久9999| 曰本三级在线| 久久最新资源网| h网站久久久| 久久精品国产精品亚洲| 91欧美在线视频| 亚洲天堂网在线观看| 深夜福利视频一区| 日韩高清免费在线| 神马一区二区三区| 精品国产人成亚洲区| 国产99久一区二区三区a片| 91精选在线观看| 国产伦一区二区| 欧美一区二区性放荡片| 国产精品久久久久精| 欧美精品18+| 国产精品一品二区三区的使用体验| 欧美系列亚洲系列| 中文字幕欧美在线观看| 91国产免费看| 中文字幕观看在线| 欧美日韩一区二区不卡| 亚洲天堂视频在线| 欧美高清视频在线高清观看mv色露露十八| 久久精品五月天| 91福利区一区二区三区| 波多野结衣激情视频| 欧美中文字幕一区二区三区亚洲| 无码久久精品国产亚洲av影片| 欧美中文字幕一区| 一级黄在线观看| 91精品国产欧美一区二区成人| 国产又粗又猛又爽又黄的| 欧美区在线观看| 国产成人精品一区二区无码呦| 日韩一区国产二区欧美三区| www.久久色| 亚洲精品ady| 国产免费永久在线观看| 中文字幕欧美国内| 毛片av在线| 欧美乱大交xxxxx| 白白色在线观看| 日本一区二区三区四区视频| 亚洲国产尤物| 91久久久一线二线三线品牌| 久久这里只有精品一区二区| 青娱乐国产91| 婷婷六月综合| xxxx18hd亚洲hd捆绑| 美女尤物久久精品| 日韩成人精品视频在线观看| 国产成人av在线影院| 国产男女猛烈无遮挡a片漫画| 国产视频一区在线观看| 777777国产7777777| 亚洲第一激情av| 波多野结衣视频观看| 欧美一区二区久久| 手机亚洲第一页| 久久亚洲精品成人| 免费成人在线电影| 成人午夜黄色影院| 日韩激情啪啪| 综合网五月天| 99亚洲伊人久久精品影院红桃| 一区二区三区视频在线观看免费| 国产成人在线免费| 中文字幕网站在线观看| 一区二区三区丝袜| 波多野结衣电车痴汉| 亚洲精品在线免费播放| 二区三区在线播放| 国内精品久久久久伊人av| 国语自产精品视频在线看抢先版结局 | 国产传媒在线看| 午夜婷婷国产麻豆精品| 一级黄在线观看| 亚洲色无码播放| 55av亚洲| 7777精品伊久久久大香线蕉语言 | 在线观看精品国产视频| 牛牛精品视频在线| 国产精品一区av| 亚洲精品国产动漫| 久久久久久av无码免费网站下载| av黄在线观看| 欧美一卡二卡在线观看| 麻豆av电影在线观看| 欧美高清视频在线| 四虎精品永久免费| 视频一区国产精品| 亚洲在线黄色| 日韩av无码一区二区三区不卡 | 精品区一区二区| 午夜免费福利在线观看| 日韩免费在线播放| 噜噜噜天天躁狠狠躁夜夜精品 | 久久香蕉精品| 漂亮人妻被黑人久久精品| 亚洲码国产岛国毛片在线| 伊人精品一区二区三区| 国产亚洲福利一区| 国产精品迅雷| 精品久久久三级| 日韩午夜免费| 超碰男人的天堂| 午夜日韩在线观看| 三级网站在线看| 高清视频欧美一级| 国产成人一二| 大伊香蕉精品视频在线| 国产成人免费xxxxxxxx| 久草视频免费播放| 精品日韩在线观看| 国精一区二区三区| 国产精品亚洲不卡a| 亚洲国产二区| 人妻无码中文久久久久专区| 午夜av一区二区三区| 欧美一级特黄aaaaaa大片在线观看| 久久久久久久91| 精品国产乱子伦一区二区| 成人性免费视频| 91免费看`日韩一区二区| 亚洲 欧美 成人| 在线播放国产精品| 欧美成a人片免费观看久久五月天| 亚洲精品成人三区| 黄网站免费久久| 精品99久久久久成人网站免费| 日韩美女一区二区三区| www.8ⅹ8ⅹ羞羞漫画在线看| 好吊妞www.84com只有这里才有精品 | 国产91xxx| 91视频xxxx| 国产一级片av| 日韩在线观看精品| 精品中文在线| 岛国大片在线播放| 99久久久无码国产精品| 香蕉污视频在线观看| 最近2019中文字幕第三页视频 | 天堂√中文最新版在线| 欧美一级二级三级| 久久99久久久欧美国产| 久久久国产成人| 日韩黄色av网站| 国产成人午夜性a一级毛片| 在线视频不卡一区二区| 国产99精品国产| 久久久精品视频网站| www.亚洲人.com| 美女视频亚洲色图| 国产嫩草在线观看| 一区二区三区毛片| 青梅竹马是消防员在线| 国产日韩在线视频| 亚洲高清资源| 日本免费www| 精品国产髙清在线看国产毛片| xxxxxx欧美| 亚洲欧美日韩不卡| 91论坛在线播放| 国产精品视频久久久久久| 98精品国产高清在线xxxx天堂| 日韩欧美综合| 国产性生活毛片| 欧美日韩国产色站一区二区三区| 国内高清免费在线视频| 亚洲自拍的二区三区| 99久久99精品久久久久久| 一级特黄录像免费看| 欧美亚洲伦理www| 日韩一区二区三区免费播放| yy1111111|