导入 ECMAScript 6 时出现“未捕获的语法错误:无法在模块外使用 import 语句”

新手上路,请多包涵

我正在使用 ArcGIS JSAPI 4.12 并希望使用 Spatial Illusions 在地图上绘制军事符号。

当我将 milsymbol.js 添加到脚本时,控制台返回错误

未捕获的语法错误:无法在模块外使用导入语句`

所以我将 type="module" 添加到脚本中,然后返回

未捕获的 ReferenceError:未定义 ms

这是我的代码:

<link rel="stylesheet" href="https://js.arcgis.com/4.12/esri/css/main.css">
<script src="https://js.arcgis.com/4.12/"></script>
<script type="module" src="milsymbol-2.0.0/src/milsymbol.js"></script>

<script>
    require([
        "esri/Map",
        "esri/views/MapView",
        "esri/layers/MapImageLayer",
        "esri/layers/FeatureLayer"
    ], function (Map, MapView, MapImageLayer, FeatureLayer) {

        var symbol = new ms.Symbol("SFG-UCI----D", { size: 30 }).asCanvas(3);
        var map = new Map({
            basemap: "topo-vector"
        });

        var view = new MapView({
            container: "viewDiv",
            map: map,
            center: [121, 23],
            zoom: 7
        });
    });
</script>

因此,无论我添加 type="module" 与否,总会有错误。但是,在Spatial Illusions的官方文档中,脚本中并没有 type="module" 。我现在真的很困惑。他们如何在不添加类型的情况下使其工作?

文件 milsymbol.js

import { ms } from "./ms.js";

import Symbol from "./ms/symbol.js";
ms.Symbol = Symbol;

export { ms };

原文由 Jerry Chen 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 640
1 个回答

我收到此错误是因为我忘记了脚本标签内的 type="module"

 <script type="module" src="milsymbol-2.0.0/src/milsymbol.js"></script>

原文由 Emmanuel 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题