webpack學習第十八步—— 生成庫文件

寫一些基本文件

// math.js
export function add(a,b) {
    return a + b
}
export function minus(a,b) {
    return a - b
}
export function multi(a,b) {
    return a * b
}
export function div(a,b) {
    return a / b
}
// string.js
export function join(a,b) {
    return a + ' ' + b
}
// index.js
import * as math from './math'
import * as string from './string'

export default {
    math,
    string
}

webpack.config.js文件

const path = require('path')

module.exports = {
    mode: 'production',
    entry: './src/index.js',
    output: {
        path: path.resolve(__dirname,'dist'),
        filename: 'library.js',
        // 在全局變量里增加library變量
        library: 'library',
        libraryTarget: "umd" //通用引入方式
    }

}
  • umd代表支持以下引入方式
import library from 'library'
const library = require('library')
requrie(['library'],function() {
})
  • 在全局變量里增加library變量
library.math
  • 如果注釋掉library: 'library',則無法使用library
  • libraryTarget為this,library則會掛載到this上(掛載this/window或者node環(huán)境下掛載到global)
library: 'library'
// 不支持commonjs、amd的引入方式,全局變量掛載到this上
libraryTarget: "this"

lib包引入三方庫如何處理

  • 修改string.js引入lodash,此時打包會有l(wèi)odash的內(nèi)容
import _ from 'lodash'
export function join(a,b) {
    return _.join(a,b)
}
  • 修改webpack.config.js,增加externals
externals: ['lodash']
  • 根據(jù)配置方式引用
externals: {
    lodash: {
        root: '_',
        commonjs: 'lodash' //庫在CommonJS環(huán)境被使用,lodash被引用時必須叫l(wèi)odash
    }
}
  • 普通配置
externals: {
    lodash: 'lodash'// 起名叫做lodash
}

npm包發(fā)布

  • 新建.npmignore文件,我們要發(fā)布的就是dist文件夾中的內(nèi)容
node_modules/
src/
webpack.config.js
username: dingsusu
password: 同QQ密碼
  • npm publish發(fā)布到倉庫上
  • 撤銷npm包 npm --force unpublish
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容