【问题标题】:"Uncaught SyntaxError: Cannot use import statement outside a module" when importing ECMAScript 6导入 ECMAScript 6 时出现“未捕获的语法错误:无法在模块外使用 import 语句”
【发布时间】:2020-09-19 00:36:56
【问题描述】:

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

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

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

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

Uncaught ReferenceError: ms is not defined

这是我的代码:

<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 };

【问题讨论】:

  • 我在尝试导入模块时遇到了同样的错误!你有什么解决办法吗?
  • 我现在正在使用 browserify,通过它我可以使用 require() 包含任何模块。看看这个video
  • 这个问题在 Stack Overflow 上的所有21,642,537 questions 中以view rate 排名前十(可能来自搜索引擎点击)。它在其生命周期内每天的浏览量约为 1800 次。

标签: javascript ecmascript-6 arcgis arcgis-js-api


【解决方案1】:

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

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

【讨论】:

    【解决方案2】:

    Node.js / NPM 更新

    "type": "module" 添加到您的package.json 文件中。

    {
      // ...
      "type": "module",
      // ...
    }
    

    注意:使用模块时,如果你得到ReferenceError: require is not defined,你需要使用import syntax而不是require。你不能在它们之间进行原生混合和匹配,所以你需要选择一个或use a bundler if you need to use both

    【讨论】:

    • 我来自this 答案,现在我处于无限循环中
    • 你找到任何解决方案了吗@wormsparty
    • 是的。基本上,不要独立运行 TypeScript 脚本,而是将它们放在现有的 Angular 项目中,一切都会正常运行;-)
    • @wormsparty Escape the loop
    【解决方案3】:

    看起来错误的原因是:

    1. 您当前正在加载src 目录中的源文件,而不是dist 目录中的构建文件(您可以看到预期的分发文件是here)。这意味着您在未更改/未捆绑状态下使用本机源代码,导致以下错误:Uncaught SyntaxError: Cannot use import statement outside a module。这应该通过使用捆绑版本来解决,因为包是using rollup 来创建捆绑包。

    2. 您收到 Uncaught ReferenceError: ms is not defined 错误的原因是因为模块是作用域的,并且由于您使用本机模块加载库,ms 不在全局作用域内,因此无法在以下脚本中访问标记。

    看起来您应该能够加载此文件的dist 版本以在window 上定义ms。查看库作者的this example,查看如何完成此操作的示例。

    【讨论】:

    • 感谢您的回复,现在我知道我的文件有误。我一直在寻找文件的 dist 版本,但没有结果。你知道有什么方法可以得到 dist 版本吗?非常感谢!
    • 它可以在 npm (npmjs.com/package/milsymbol) 上下载。或者,您可以通过克隆存储库并运行其中一个构建脚本来自己构建它。看起来有一个 AMD 构建脚本 (github.com/spatialillusions/milsymbol/blob/master/…) 应该允许您将构建的包直接 require 到您的代码中。
    • 我已经通过 npm 下载,现在我有脚本:&lt;script src="node_modules/milsymbol/dist/milsymbol.js"&gt;&lt;/script&gt;,但控制台仍然返回Uncaught ReferenceError: ms is not defined。问题是ms 没有在dist/milsymbol.js 中定义,它在src/milsymbol.js 中定义,但它需要type="module" 并且会导致范围问题。有什么解决方案。非常感谢!
    • 如果那是实际意图,从 /src 引用它怎么办。由于作者不打算公开一个类的属性,例如..
    【解决方案4】:

    在将 type="module" 添加到脚本之前,我也面临同样的问题。

    以前是这样的

    <script src="../src/main.js"></script>
    

    然后改成

    <script type="module" src="../src/main.js"></script>
    

    效果很好。

    【讨论】:

    • 让 CORS 做这件事
    • 表示您正在从另一个域请求。您可以通过在标题中添加Access-Control-Allow-Origin: * 来解决此问题。你可以在developer.mozilla.org/en-US/docs/Web/HTTP/…查看有关 CORS 的 MDN 文档。
    • 不知道 cors,问题是这些是我的本地文件
    • 您需要在 http 服务器中提供脚本,浏览器使用 http 请求加载 es6 模块,服务器需要在标头中响应允许您的来源的 CORS。
    • 最简单的方法:可以使用http-server:stackoverflow.com/a/23122981/935330
    【解决方案5】:

    我通过执行以下操作解决了这个问题:

    在浏览器中使用 ECMAScript 6 模块时,请在文件中使用 .js 扩展名,并在脚本标签中添加 type = "module"

    在 Node.js 环境中使用 ECMAScript 6 模块时,请在文件中使用扩展名 .mjs 并使用以下命令运行文件:

    node --experimental-modules filename.mjs
    

    编辑:这是在 node12 是最新的 LTS 时编写的,这不适用于 node 14 LTS。

    【讨论】:

    • 模块:ECMAScript 模块:启用 https://nodejs.org/api/esm.html#esm_enabling
    • 这不再是必要的。只需将 "type": "module" 添加到您的 package.json 中,一切都会按预期工作。 (使用 .js 作为文件扩展名)
    【解决方案6】:

    我通过将“import”替换为“require”解决了我的问题。

    // import { parse } from 'node-html-parser';
    const parse = require('node-html-parser');
    

    【讨论】:

    • 谢谢,我也用这个语法解决了我的问题
    • const {parse} = require('node-html-parser'); 为我工作
    • 解释是什么?为什么这行得通?请通过editing (changing) your answer 回复,而不是在 cmets 中(without "Edit:"、"Update:" 或类似的 - 答案应该看起来像是今天写的)。
    • 在节点中对我造成此问题的确切软件。
    • 问题是关于浏览器的
    【解决方案7】:

    我不知道这是否在这里显得很明显。我想指出,就客户端(浏览器)JavaScript 而言,您可以将 type="module" 添加到外部和内部 js 脚本中。

    说,你有一个文件'module.js':

    var a = 10;
    export {a};
    

    您可以在执行导入的外部脚本中使用它,例如:

    <!DOCTYPE html><html><body>
    <script type="module" src="test.js"></script><!-- Here use type="module" rather than type="text/javascript" -->
    </body></html>
    

    test.js:

    import {a} from "./module.js";
    alert(a);
    

    您也可以在内部脚本中使用它,例如:

    <!DOCTYPE html><html><body>
    <script type="module">
        import {a} from "./module.js";
        alert(a);
    </script>
    </body></html>
    

    值得一提的是,对于相对路径,不能省略“./”字符,即:

    import {a} from "module.js";     // this won't work
    

    【讨论】:

      【解决方案8】:

      对我来说,这是由于没有将库(特别是typeORM,使用ormconfig.js 文件,在entities 键下)引用到src 文件夹,而不是dist 文件夹。 .

         "entities": [
            "src/db/entity/**/*.ts", // Pay attention to "src" and "ts" (this is wrong)
         ],
      

      而不是

         "entities": [
            "dist/db/entity/**/*.js", // Pay attention to "dist" and "js" (this is the correct way)
         ],
      

      【讨论】:

      • 至少对我来说,你的答案并不清楚你说的哪个是正确的方法
      • @claudekennilol - 感谢您的评论,我已经编辑了答案以消除歧义
      【解决方案9】:

      我在React 中遇到了这个错误,并通过以下步骤修复了它:

      1. 进入项目根目录,打开Package.json文件进行编辑。

      2. 添加"type":"module";

      3. 保存并重启服务器。

      【讨论】:

        【解决方案10】:

        如果您想对模块使用 import 而不是 require(),请将 type 的值更改或添加到 module 文件中的 module

        例子:

        package.json 文件

        {
          "name": "appsample",
          "version": "1.0.0",
          "type": "module",
          "description": "Learning Node",
          "main": "app.js",
          "scripts": {
            "test": "echo \"Error: no test specified\" && exit 1"
          },
          "author": "Chikeluba Anusionwu",
          "license": "ISC"
        }
        
        import http from 'http';
        
        var host = '127.0.0.1',
            port = 1992,
            server = http.createServer();
        
        server.on('request', (req, res) => {
          res.writeHead(200, {"Content-Type": "text/plain"});
          res.end("I am using type module in package.json file in this application.");
        });
        
        server.listen(port, () => console.log(
            'Listening to server ${port}. Connection has been established.'));
        

        【讨论】:

        • 这解决了我的问题。
        • 太棒了!我很高兴它做到了。
        【解决方案11】:

        这对我有帮助:

        1. 在我使用的 .ts 文件中:import prompts from "prompts";
        2. 并在文件 tsconfig.json 中使用了"module": "commonjs"

        【讨论】:

        • 它是什么.ts文件?
        • 您的代码需要添加一些模块导入的任何 typeScript 或 JavaScript 文件。
        【解决方案12】:

        我正在使用原生 JavaScript 进行编码。如果您也这样做,只需将 type="module" 添加到您的脚本标签。

        也就是之前的代码:

        <script src="./index.js"></script>
        

        更新代码:

        <script type="module" src="./index.js"></script>`
        

        【讨论】:

        【解决方案13】:

        有三种方法可以解决这个问题:

        1.第一种:在脚本中包含type=module

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

        2。第二个:在node.js中,进入你的package.json文件

            {
                // ...
                "type": "module",
                // ...
            }
        

        3.第三种:使用import by required

            import { parse } from 'node-html-parser';
            parse = require('node-html-parser');
        

        【讨论】:

          【解决方案14】:

          为什么会发生这种情况以及更多可能的原因:

          很多接口仍然不理解ES6 JavaScript 语法/功能。因此,无论何时在任何文件或项目中使用 ES6,都需要将其编译为 ES5

          SyntaxError: Cannot use import statement outside a module 错误的可能原因是您尝试独立运行文件。您尚未安装和设置 ES6 编译器,例如 Babel,或者您的 runscript 中的文件路径错误/不是编译后的文件。

          如果您想在没有编译器的情况下继续,最好的解决方案是使用 ES5 语法,在您的情况下是 var ms = require(./ms.js);。这可以稍后根据需要进行更新,或者更好地设置您的编译器并确保您的文件/项目在运行之前已编译,并确保您的运行脚本正在运行通常命名为 dist、build 或您命名的任何文件的编译文件以及指向你的runscript中编译的文件是正确的。

          【讨论】:

            【解决方案15】:

            触发错误是因为您在 HTML 文件中链接到的文件是该文件的非捆绑版本。 要获得完整的捆绑版本,您必须使用 npm 安装它:

            npm install --save milsymbol
            

            这会将完整包下载到您的node_modules 文件夹。

            然后,您可以通过 node_modules/milsymbol/dist/milsymbol.js 访问独立的缩小 JavaScript 文件

            您可以在任何目录中执行此操作,然后只需将以下文件复制到您的/src 目录。

            【解决方案16】:

            使用此代码。对我来说效果很好:

            将此脚本标签添加到文件index.html

            <script type="module">
                import { ms } from "./ms.js";
                import Symbol from "./ms/symbol.js";
            </script>
            

            【讨论】:

            【解决方案17】:

            我在尝试使用 import Express.js 时遇到了这个错误。

            而不是 import express from 'express';

            我使用了 const express = require('express');

            【讨论】:

              【解决方案18】:

              EXPO 遇到了同样的错误。

              主要解决方法是在package.json文件中添加"type": "module",

              但是,您必须检查哪个是正确的 package.json。

              在我的例子中,有两个 package.json 文件,那么你应该将它添加到服务器文件中。

              要确定哪个是正确的 package.json,请找到 "scripts": { "test": "echo \"Error: no test specified\" &amp;&amp; exit 1" },

              下面↑ 这行,加"type": "module",

              【讨论】:

              【解决方案19】:

              就我而言,我更新了

              "lib": [
                    "es2020",
                    "dom"
                  ]
              

              "lib": [
                "es2016",
                "dom"
              ]
              

              在我的 tsconfig.json 文件中。

              【讨论】:

              • 谢谢,您的评论引导我安装:@babel/preset-env,并且通过 npm install,我可以使用 import 语句。
              • @Thuy 很好。我很高兴你解决了这个问题
              【解决方案20】:

              我刚刚在我的 Package.json 文件中添加了“type”:“module”,它对我有用。

              【讨论】:

              【解决方案21】:

              提供的答案都不适合我,但我找到了不同的解决方案:How to enable ECMAScript 6 imports in Node.js

              安装 ESM:

              npm install --save esm
              

              使用 ESM 运行:

              node -r esm server.js
              

              【讨论】:

                【解决方案22】:

                好吧,就我而言,我不想更新我的 package.json 文件并将文件类型更改为 mjs。

                所以我环顾四周,发现更改文件 tsconfig.json 中的模块会影响结果。我的 ts.config 文件是:

                {
                  "compilerOptions": {
                    "target": "es2020",
                    "module": "es2020",
                    "lib": [
                      "es2020",
                    ],
                    "skipLibCheck": true,
                    "sourceMap": true,
                    "outDir": "./dist",
                    "moduleResolution": "node",
                    "removeComments": true,
                    "noImplicitAny": true,
                    "strictNullChecks": true,
                    "strictFunctionTypes": true,
                    "noImplicitThis": true,
                    "noUnusedLocals": true,
                    "noUnusedParameters": true,
                    "noImplicitReturns": true,
                    "noFallthroughCasesInSwitch": true,
                    "allowSyntheticDefaultImports": true,
                    "esModuleInterop": true,
                    "emitDecoratorMetadata": true,
                    "experimentalDecorators": true,
                    "resolveJsonModule": true,
                    "baseUrl": "."
                  },
                  "exclude": [
                    "node_modules"
                  ],
                  "include": [
                    "./src/**/*.ts"
                  ]
                }
                

                像这样将模块从 "module": "es2020" 更改为 "module" : "commonjs" 解决了我的问题。

                我正在使用MikroORM,并认为它可能不支持CommonJS 以上的任何模块。

                【讨论】:

                  【解决方案23】:

                  那是因为你还没有导出。 .ts 文件需要导出类格式,而在 .js 文件中我们将使用 exports 函数。

                  所以,我们必须使用var_name = require("&lt;pathfile&gt;") 来使用这些文件功能。

                  【讨论】:

                  • 您好...检查//观看...您的答案没有详细说明。插入带有代码和参考的有效响应很有用。得出一个切实有效的解决方案。这个平台不仅仅是任何论坛。我们是世界上其他程序员和开发人员最大的帮助和支持中心。查看社区条款并了解如何发帖;
                  【解决方案24】:

                  将 "type": "module", 添加到您的 package.json 文件中。

                  然后重新启动您的应用程序:

                  run npm start
                  

                  那么你的问题就解决了。

                  【讨论】:

                  • 逗号是不是一部分?
                  【解决方案25】:

                  我必须将一些数据从外部文件(js 文件)导入到我的 html 文件中的 script.js。

                  数据.js

                  const data = {a: 1, b: 2}
                  

                  通过添加type=module 我得到cors 错误。

                  我发现我可以将data.js 导入到我的script.js 中,只需包含 data.js 在我的 html 文件中。

                  例如, 以前我的 html 文件包含

                  <script src="assets/script.js"></script>
                  

                  由于我需要来自 data.js 的一些数据,我只是将我的 html 文件更改为

                  <script src="assets/data.js"></script>
                  <script src="assets/script.js"></script>
                  

                  即在script.js 之前包含data.js,从而可以访问script.js 中的我的数据变量

                  【讨论】:

                    【解决方案26】:

                    只需在src&lt;script&gt; 标记中的名称和扩展名之间添加.pack

                    即:

                    <script src="name.pack.js">
                        // Code here
                    </script>
                    

                    【讨论】:

                      【解决方案27】:

                      Babel transpile 中失败时会出现此错误。

                      【讨论】:

                      猜你喜欢
                      • 2021-05-15
                      • 1970-01-01
                      相关资源
                      最近更新 更多