首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >升级Gulp之后,javascript将抛出一个语法错误“导入声明只能出现在模块的顶层”。

升级Gulp之后,javascript将抛出一个语法错误“导入声明只能出现在模块的顶层”。
EN

Stack Overflow用户
提问于 2020-05-31 16:08:48
回答 1查看 232关注 0票数 1

我有一个gulpfile.js,它可以监视文件夹中的文件更改。在我从Gulp3.9.1升级到4.0.2之前,一切都很好。在升级Gulp时,我还将node.js升级为最新的v12.17.0

下面是打包js文件的gulp任务

代码语言:javascript
复制
var gulp = require("gulp"),
    concat = require("gulp-concat"),
    filter = require('gulp-filter'),
    merge = require("merge-stream");

gulp.task("min:js", function () {
    var tasks = [];

    var task = gulp.src(['path_1/**/*.js', 'path_2/**/*.js'], { base: "." })
            .pipe(filter('**/*.js'))
            .pipe(concat('output.js'))
            .pipe(gulp.dest("."));

    tasks.push(task);

    return merge(tasks);
});

该任务生成以下代码

代码语言:javascript
复制
// More Js code...
import { setTimeout } from "timers";

'use strict';
// more js code.....

但是import { setTimeout } from "timers";行抛出了以下错误

SyntaxError:导入声明只能出现在模块级别

如何纠正此错误?

EN

回答 1

Stack Overflow用户

发布于 2020-05-31 16:24:09

上述问题可能是由于试图将setTimeout作为模块导入造成的。

setTimeout是一个标准的javascript函数,不需要显式导入。因此,删除导入语句可以解决此问题。

如果上述步骤没有解决问题,则可以尝试以下操作:

将type=“模块”属性添加到包含模块的HTML标记中。

代码语言:javascript
复制
<script type="module" src="my-module.js"></script>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62118965

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档