Wie erstelle und verwende ich eine eigene JS-Bibliothek eines Drittanbieters mit Webpack?
为情所困
为情所困 2017-05-19 10:47:18
0
3
522

Ich bin neugierig, wie so etwas wie jQueryReact这些打包好的库加载之后可以在全局中使用$,jQueryReact来访问,想知道自己构建的库如何做到可以在全局中像React weltweit eingesetzt werden könnte.

Ich habe festgestellt, dass nach der Webpack-Verpackung die definierten zugehörigen Objekte überhaupt nicht global gefunden werden konnten.

为情所困
为情所困

Antworte allen(3)
曾经蜡笔没有小新

打包成 library 即可,请详读 https://webpack.js.org/guides...

给我你的怀抱

webpack打包后都是闭包, 全局怎么可能访问的到

要想全局访问的到, 必须在webpack里添加new webpack.ProvidePlugin的相关配置

比如

new webpack.ProvidePlugin({$: 'jquery', jQuery: 'jquery', 'window.jQuery': 'jquery'})
为情所困

一般直接把你的主对象(或类)注册到全局对象上就好了,比如可以模仿 jQuery 注册方法(去掉了判断 document 的那一段):

(function(global, factory) {
    "use strict";
    // 兼容模块化框架(主要是 AMD 框架)
    if (typeof module === "object" && typeof module.exports === "object") {
        module.exports = factory(global);
    } else {
        factory(global);
    }
})(typeof window !== "undefined" ? window : this, function(global) {
    // 这里是你的库代码
    global = MyLibEntry;
});

如果你是采用的模块化写法,可以在入口模块上写上述代码。

Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage