js importmap

在html文件中使用npm 下载的包,比如vue,在使用import引入的时候会报错

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body></body>
  <script type="module">
    import { createApp } from "vue";
    console.log(createApp());
  </script>
</html>

Uncaught TypeError: Failed to resolve module specifier "vue". Relative references must start with either "/", "./", or "../".
因为在浏览器环境中必须使用/,./或者../来表示路径的,在平时项目开发中都是使用的webpack或者vite来进行开发,他们都是基于node.js环境的,我们就想这样使用咋办?这时候就需要使用importmap了

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body></body>
  <script type="importmap">
    {

        "imports":{
            "vue":"./node_modules/vue/dist/vue.esm-browser.js"
        }
    }
  </script>
  <script type="module">
    import { createApp } from "vue";
    console.log(createApp());
  </script>
</html>

这样就能正常引入包了,这里的vue可以随便取名,abc也行,只要下面引入的名字和这里对应起来就行了

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
importmap 是一个新的 JavaScript 提案,它为 JavaScript 应用程序提供了一种声明性的方式来定义模块的依赖关系。使用 importmap 可以避免在开发过程中使用不同的 JavaScript 模块加载器时出现的问题,例如 Node.js 中的 require 和浏览器中的 ES6 模块语法。 要使用 importmap,您需要在 HTML 页面的 head 部分添加一个 script 标签,并将 type 属性设置为 "importmap"。例如: ```html <head> <script type="importmap"> { "imports": { "lodash": "https://cdn.jsdelivr.net/npm/lodash@4.17.20/lodash.min.js", "react": "https://cdn.jsdelivr.net/npm/react@16.13.1/umd/react.production.min.js", "react-dom": "https://cdn.jsdelivr.net/npm/react-dom@16.13.1/umd/react-dom.production.min.js" } } </script> </head> ``` 在上面的示例中,我们定义了三个模块的依赖关系,分别是 lodash、react 和 react-dom。我们可以在应用程序中以相同的方式导入这些模块: ```javascript import _ from 'lodash'; import React from 'react'; import ReactDOM from 'react-dom'; ``` 在加载页面时,浏览器会根据 importmap 中定义的依赖关系自动加载所需的模块。如果您的应用程序依赖于其他模块,您可以将它们添加到 importmap 中。您还可以使用本地路径或相对路径来指定模块的位置,例如: ```html <head> <script type="importmap"> { "imports": { "my-module": "/path/to/my-module.js" } } </script> </head> ``` 在这种情况下,my-module 模块将从当前页面的根目录中加载。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值