vite2的库项目,打包发布到npmjs.com的方法

官网资料

构建生产版本——库模式
https://cn.vitejs.dev/guide/build.html#library-mode

详细设置
https://cn.vitejs.dev/config/#build-lib

用 rollup 打包发布

以前只会用 webpack 的方式打包,用 vue-cli 建立项目,然后打包。这样打的包比较大,里面“无用”的内容比较多,我喜欢清爽型的,听说 rollup 打包的内容会少很多,而且项目也都改用 vite 来创建,用 rollup 打包可以更方便一些。

写代码

先写一个简单的功能做测试。
做一个获取类型、判断类型的小工具 https://www.jianshu.com/p/422805e6f793
这个代码比较简单,一个js文件即可,正好用来做测试。
建立一个新的 vite 项目,建立 lib 文件夹,里面设置一个 main.js 文件

lib/main.js

    /**
   * 用 call 的方式获取类型
   * @param {*} val 要验证的实例
   * @returns
   * *   '[object Object]',
   * *   '[object Array]',
   * *   '[object Map]',
   * *   '[object Set]',
   * *   '[object Function]',
   * *   '[object AsyncFunction]',
   * *   '[object Promise]',
   * *   '[object Symbol]',
   * *   '[object String]',
   * *   '[object Number]',
   * *   '[object BigInt]',
   * *   '[object RegExp]',
   * *   '[object Date]',
   * *   '[object Math]',
   * *   '[object Null]',
   * *   '[object Undefined]'
   * *   其他
   */
  const toTypeString = (val) => { 
    return Object.prototype.toString.call(val)
  }
  
  /**
   * 获取具体类型
   * @param {*} val 要验证的实例
   * @returns 
   * *   'function',
   * *   'async',
   * *   'object',
   * *   'array',
   * *   'string',
   * *   'number',
   * *   'bigInt',
   * *   'regExp',
   * *   'date',
   * *   'map',
   * *   'set',
   * *   'promise',
   * *   'symbol',
   * *   'math',
   * *   'null',
   * *   'undefined'
   * *   其他
   */
  const typeName = (val) => {
    return Object.prototype.toString.call(val).replace(/^\[object (\S+)\]$/,'$1').toLowerCase()
  }

  const hasOwnProperty = Object.prototype.hasOwnProperty
  const hasOwn = (val, key) => hasOwnProperty.call(val, key)

  /**
   *  验证普通函数
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isFunction = (val) => toTypeString(val) === '[object Function]'

  /**
   * 验证 async 的函数
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isAsync = (val) => toTypeString(val) === '[object asyncFunction]'
 
  /**
   * 验证 Object,不含 null
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isObject = (val) => val !== null && typeof val === 'object'
 
  /**
   *  验证数组
   * @param {*} val 要验证的对象
   * @returns 
   */
   const isArray = Array.isArray
 
   /**
   * 验证字符串
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isString = (val) => typeof val === 'string'
 
  /**
   * 验证 number
   * @param {*} val 要验证的对象
   * @returns 
   */
 
  const isNumber = (val) => typeof val === 'number'
 
  /**
   * 验证 BigInt
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isBigInt = (val) => typeof val === 'bigint'
 
  /**
   * 验证 boolean
   * @param {*} val 要验证的对象
   * @returns 
   */
   const isBoolean = (val) => typeof val === 'boolean'
 
   /**
   * 验证正则类型
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isRegExp = (val) => toTypeString(val) === '[object RegExp]'
  /**
   * 验证日期
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isDate = (val) => val instanceof Date

  /**
   * 验证 map
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isMap = (val) => toTypeString(val) === '[object Map]'
  /**
   * 验证 set
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isSet = (val) => toTypeString(val) === '[object Set]'
  /**
   *  验证 Promise
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isPromise = (val) => toTypeString(val) === '[object Promise]'
  /**
   * 验证 Symbol
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isSymbol = (val) => typeof val === 'symbol'

  /**
   * null 或者 undefined 返回 true
   * @param {*} val 要验证的对象
   * @returns 
   */
  const isNullOrUndefined = (val) => {
    if (val === null) return true
    if (typeof val === 'undefined') return true
    return false
  }
 

export {
  toTypeString, // Object.prototype.toString.call(val)
  typeName, // 获取可以识别的名称

  hasOwnProperty,
  hasOwn,

  isFunction, // 验证普通函数
  isAsync, // 验证 async 的函数
  isObject, // 验证 Object
  isArray, // 验证数组
  isString, // 验证字符串
  isNumber, // 验证 number
  isBigInt, // 验证 BigInt
  isBoolean, // 验证 布尔
  isRegExp, // 验证正则类型
  isDate, // 验证日期
  isMap, // 验证 map
  isSet, // 验证 set
  isPromise, // 验证 Promise
  isSymbol, // 验证 Symbol
 
  isNullOrUndefined // null 或者 undefined 返回 true
}
  • 文件名
    文件名应该可以随意写,只要在 vite.config.js 里面设置好即可,main.js 是参考官网设置的。

  • jsDoc
    jsDoc 可以在引用的地方出现提示,只是打包之后就没有了,也许必须用TS才能带上提示吗?

代码写好之后,我们开始做各种设置。

vite.config.js的设置

按照官网做设置,这里的写法和官网有点区别,但是测试可用。

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import { resolve } from 'path' // 主要用于alias文件路径别名

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue()],
  // 打包配置
  build: {
    lib: {
      entry: resolve(__dirname, 'lib/main.js'),
      name: 'rollup-plugin-nf-typeof',
      fileName: (format) => `rollup-plugin-nf-typeof.${format}.js`
    },
    sourcemap: true,
    rollupOptions: {
      // 确保外部化处理那些你不想打包进库的依赖
      external: ['vue'],
      output: {
        // 在 UMD 构建模式下为这些外部化的依赖提供一个全局变量
        globals: {
          vue: 'Vue'
        }
      }
    }
  }
})

vite 会按照这里的设置进行打包,打包分为两种模式,一个是umd 的形式,另一个就是es的模式,这个打包后和我们写的代码基本没啥区别。

  • entry
    指定要打包的入口文件。

  • name
    包的名称

  • fileName
    包文件的名称,默认是umd和es两个文件。

  • sourcemap
    是否生成 .map 文件,默认是不会生成的,如果需要的话需要设置为 true。

  • rollupOptions
    如果项目引用了第三方插件,那么需要在这里设置排除,如果不设置的话,第三方插件的源码也会被打包进来,这样打包文件就变大了。排除之后第三方的插件会单独存在。

package.json 的设置

这里是在 npmjs.com上面发布的时候需要的设置,这里的设置要和vite.config.js的设置相对应。

{
  "name": "rollup-plugin-nf-typeof",
  "version": "0.0.4",
  "description": "验证JavaScript的数据类型。",
  "files": ["dist"],
  "main": "./dist/rollup-plugin-nf-typeof.umd.js",
  "module": "./dist/rollup-plugin-nf-typeof.es.js",
  "exports": {
    ".": {
      "import": "./dist/rollup-plugin-nf-typeof.es.js",
      "require": "./dist/rollup-plugin-nf-typeof.umd.js"
    }
  },
  "private": false,
  "license": "MIT",
  "auther": "jin yang (jyk) jyk0013@163.com",
  "scripts": {
    "dev": "vite",
    "build": "vite build",
    "serve": "vite preview"
  }
}
  • name: 资源包的名称。
  • version:版本号,每次发布都要更新一下版本号。
  • files: 打包后的文件夹名称。
  • 设置资源包的名称:设置好就对了,如果写错了就会找不到文件。

发布

在npmjs.com上面发布的方式是一样的。注册、登录、发布即可。
整理一下在 npmjs.com 上面发布资源包踩过的坑:https://www.jianshu.com/p/3de34c804f64

安装使用

这个包只是普通的 webpack 的包,所以正常安装即可:

npm i rollup-plugin-nf-typeof
或者
yarn add rollup-plugin-nf-typeof

组件里面使用:

import { isArray } from 'rollup-plugin-nf-typeof'

    const arr = []
    console.log(isArray(arr))

使用效果

没有使用map的效果:

无map

使用mao的效果:

有map

使用map之后,就和我们写的代码一模一样了,这样调试起来就更方便。

注意

这个并不是vite的插件,所以使用的时候不需要在vite.config.js里面做设置。
如果是vite的插件,才需要做设置。

那么vite的插件如何编写呢?还没有完全弄明白。。。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容