Typescript 未捕获引用错误:\未定义网页包\外部\模块\ XX \未定义

Typescript 未捕获引用错误:\未定义网页包\外部\模块\ XX \未定义,typescript,npm,webpack,arcgis-js-api,Typescript,Npm,Webpack,Arcgis Js Api,我们有一个定制的npm包,我们的地图,我们使用TypeScript、webpack和ArcGIS JS API将esri地图包装到React组件中。我们已从模块内的测试页面确认模块按预期工作。也就是说,我们可以显示React Map组件并正确地获取web地图。我们的mapnpm包被写入文件共享,这样我们就可以将它安装到其他应用程序中 我们已将npm安装到另一个TypeScript应用程序上。我们使用webpack捆绑应用程序。但是,在运行时我们会收到以下错误 Uncaught Reference

我们有一个定制的npm包,
我们的地图
,我们使用TypeScript、webpack和ArcGIS JS API将esri地图包装到React组件中。我们已从模块内的测试页面确认模块按预期工作。也就是说,我们可以显示React Map组件并正确地获取web地图。
我们的map
npm包被写入文件共享,这样我们就可以将它安装到其他应用程序中

我们已将npm安装到另一个TypeScript应用程序
上。我们使用webpack捆绑应用程序。但是,在运行时我们会收到以下错误

Uncaught ReferenceError: __WEBPACK_EXTERNAL_MODULE_61__ is not defined
在chrome中调试时,我们发现有问题的模块

module.exports = __WEBPACK_EXTERNAL_MODULE_61__;

//////////////////
// WEBPACK FOOTER
// external "esri/arcgis/utils"
// module id = 61
// module chunks = 0
如果我们将
esri/arcgis/utils
模块从
我们的地图
模块中删除并重新发布,则会出现类似的错误,但会引用下一个esri模块

我们的应用程序的代码是:

index.html

<!DOCTYPE html>
<html>
  <head>
    <title>Our Application</title>
  </head>

  <body>
    <div id="header"></div>
    <div id="content"></div>
    <div id="footer"></div>
    <script src="https://js.arcgis.com/3.16/"></script>
    <script>
            require(["dist/main.bundle.js"], function (main) {});
        </script>
  </body>
</html>

关于什么可能导致此问题以及如何解决此问题,您有什么想法吗?

解决方案是在webpack.config.js文件中设置
libraryTarget:'amd'
,如下所示:

output: {
    filename: 'dist/[name].bundle.js',
    libraryTarget: 'amd'
},
var webpack = require("webpack");

module.exports = {
    entry: {
        main: ['./src/app/main.ts', 'esri', 'esri/map', 'esri/urlUtils', 'esri/geometry/Point', 'esri/arcgis/utils']
    },
    output: {
        filename: 'dist/[name].bundle.js'
    },
    resolve: {
        extensions: ['', '.webpack.js', '.web.js', '.ts', '.tsx', '.js']
    },
    module: {
        loaders: [
            //typescript
            {
                test: /\.tsx?$/,
                loader: 'ts-loader'
            },
            // css
            {
                test: /\.css$/,
                loader: "style-loader!css-loader"
            },
            // images
            {
                test: /\.png$/,
                loader: "url-loader",
                query: { mimetype: "image/png" }
            },
            // fonts
            {
                test: /\.woff(2)?(\?v=[0-9]\.[0-9]\.[0-9])?$/,
                loader: "url-loader?limit=10000&name=dist/fa/[hash].[ext]&mimetype=application/font-woff"
            },
            {
                test: /\.(ttf|eot|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
                loader: "file-loader?name=dist/fa/[hash].[ext]"
            }
        ]
    },
    externals: [
        function(context, request, callback) {
            if (/^dojo/.test(request) ||
                /^dijit/.test(request) ||
                /^esri/.test(request)
            ) {
                return callback(null, "amd " + request);
            }
            callback();
        }
    ],
    devtool: 'source-map'
};
output: {
    filename: 'dist/[name].bundle.js',
    libraryTarget: 'amd'
},