导入js中的变量

问题描述

config.js 定义变量

const baseUrl = "http://localhost:8081";
export default baseUrl;

american-data.js 使用变量

import baseUrl from "./config.js";
console.log("baseUrl", baseUrl);

American.html 使用模块

// 使用这个模块
<script type="text/javascript"   src="../js/America-data.js"></script>

但是报错了:
在这里插入图片描述

问题解决

这个错误通常表示你正在尝试在一个非模块化的环境中使用 import 语句,而 import 语句只能在 ES6 模块中使用。

确保你的 JavaScript 文件是一个模块,你可以通过在文件中添加 type="module" 的方式来声明:

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

或者,如果你是在 Node.js 环境中使用 ES6 模块,你需要确保文件扩展名为 .mjs,或者在 package.json 中设置 "type": "module"

确保你的环境支持 ES6 模块,并正确设置了文件类型或环境配置,以便使用 import 语句。

所以改成:

 <script type="module" src="../js/America-data.js"></script>

原因

<script type="module" src="../js/America-data.js"></script>
<script type="text/javascript" src="../js/America-data.js"></script> 有什么区别???

在 HTML 中,<script> 标签的 type 属性用于指定脚本的内容类型。常见的类型包括:

  • text/javascript: 默认的脚本类型,适用于 JavaScript。
  • module: 指示脚本是一个 ES6 模块,支持使用 importexport 关键字。

现在来解释这两种不同的 script 标签的区别:

  1. <script type="module" src="../js/America-data.js"></script>:

    • 这个标签告诉浏览器,America-data.js 是一个 ES6 模块。
    • 浏览器会按照模块的方式加载和执行该脚本,意味着它会创建一个单独的作用域,并且支持使用 importexport 语法。
    • 该脚本内部的所有 import 语句都会被视为模块的导入,而不是普通的脚本引入。
  2. <script type="text/javascript" src="../js/America-data.js"></script>:

    • 这个标签告诉浏览器,America-data.js 是普通的 JavaScript 脚本。
    • 浏览器会按照传统的方式加载和执行该脚本,脚本内部的所有代码都在相同的全局作用域中运行。
    • 不支持使用 importexport,而是使用传统的全局变量和函数引入方法。

因此,如果 America-data.js 是一个 ES6 模块,你应该使用第一个 <script> 标签;如果它是一个传统的 JavaScript 脚本,你可以使用第二个标签。

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值