![](/img/trans.png)
[英]Webpack: Exposing global variable without using ProvidePlugin and expose-loader
[英]Webpack ProvidePlugin global variable (Cannot find module)
我對Webpack很新,但無法弄清楚為什么我的ProvidePlugin調用沒有按預期工作。
我有以下文件:
var App = function() {
getSomething: function(size) {}
}();
module.exports = App;
我希望這個'App'變量可以全局訪問,因為其他文件使用它如下:
var Layout = function () {
App.getSomething('md');
}();
在webpack.config.js中,我有以下行:
new webpack.ProvidePlugin({ App: 'app' })
這是我的條目:
entry: {
'app': './angularApp/metronicapp.ts',
}
import './metronic/global/scripts/app';
app
是我上面顯示的app.js
我在瀏覽器中收到以下錯誤: Cannot find module "app"
當我在控制台中編譯webpack時: Module not found: Error: Can't resolve 'app'
我無法想象我錯過了什么。 我的app.js格式不正確嗎? 為什么App
還沒有全球可用?
ProvidePlugin
需要您的全局模塊App.js
的路徑。
const path = require('path');
...
plugins: [
new webpack.ProvidePlugin({
App: path.resolve(__dirname, './path_to_App.js')
})
]
對於Typescript,不要抱怨未定義的構造創建global.d.ts
declare var App: any;
無需在metronicapp.ts
導入./metronic/global/scripts/app
將在構建時解析App
。
App.getSomething('foo');
var Layout = function() {
App.getSomething('md');
}();
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.