为了账号安全,请及时绑定邮箱和手机立即绑定

在 babel-standalone 中使用 ES 模块

在 babel-standalone 中使用 ES 模块

繁星淼淼 2023-03-03 10:45:45
引用 babel 文档https://babeljs.io/docs/en/babel-standalone#usage:“如果你想使用你的浏览器对 ES 模块的原生支持,你通常需要在你的脚本标签上设置一个 type="module" 属性。使用@babel/standalone,设置一个 data-type="module" 属性来代替“但是出于某种原因,当包含我的主要 index.js 文件(使用导入导入其他 js / jsx 文件)时,babel 似乎正在将我的导入语句转换为 require 语句,因为我得到 ReferenceError: require is not defined。我发现解决这个问题的唯一方法是使用 transform-modules-umd 插件并将我所有的 js 文件包含为脚本。不确定这是否是 data-type="module" 不起作用的错误,或者我是否遗漏了什么。这些是我在 index.html 中的脚本标签<script src="https://unpkg.com/react@16/umd/react.development.js" crossorigin></script><script src="https://unpkg.com/react-dom@16/umd/react-dom.development.js" crossorigin></script><script src="https://unpkg.com/@babel/standalone/babel.min.js"></script><script src="index.js" type="text/babel" data-type="module"></script>谢谢您的帮助
查看完整描述

2 回答

?
墨色风雨

TA贡献1853条经验 获得超6个赞

对于(我的)未来参考,这是一个完整的工作示例。


你可以将下面的代码放入 index.html 并在网络浏览器中运行它,你将拥有一个使用 JSX 的 React 应用程序。


来源: https: //codesandbox.io/s/dikoh?file =/index.html


  <!DOCTYPE html>

  <html>

    <head>

      <meta charset="UTF-8" />

      <meta name="viewport" content="width=device-width, initial-scale=1.0" />

      <meta http-equiv="X-UA-Compatible" content="ie=edge" />

      <title>Static Template</title>

    </head>

    <body>

      <div id="main"></div>

  

      <script src="https://unpkg.com/@babel/standalone/babel.min.js"></script>

      <script type="text/babel" data-presets="react" data-type="module">

        import {

          ChakraProvider,

          Box,

          Text

        } from "https://cdn.skypack.dev/@chakra-ui/react";

        import React, { useRef } from "https://cdn.skypack.dev/react";

        import ReactDOM from "https://cdn.skypack.dev/react-dom";

  

        const MyText = ({ color, ...props }) => {

          return <Text fontWeight="bold" as="span" {...props} />;

        };

  

        function Foo() {

          return (

            <div>

              Foo

            </div>

          );

        }

  

        function App() {

          return (

            <Box>

              Hello <MyText>Skypack</MyText>

              <Foo/>

            </Box>

          );

        }

  

        ReactDOM.render(

          <ChakraProvider>

            <App />

          </ChakraProvider>,

          document.getElementById("main")

        );

      </script>

    </body>

  </html>


查看完整回答
反对 回复 2023-03-03
?
翻过高山走不出你

TA贡献1875条经验 获得超3个赞

Amareis 在 babel 的 github 页面上回答了我的问题:https://github.com/babel/babel/discussions/12059

问题是 babel 不会转译通过 ES 模块导入的模块,它们必须明确包含为脚本,并将“type”设置为“text/babel”。所以通过 index.js 脚本中的 ES 模块导入的 JSX 文件是在 index.js 被 babel 转译后导入的,而不是它自己转译。

还得到了一个建议,为了开发目的,使用 service worker 获取并执行我的脚本。babel-standalone 在获取后转换它们


查看完整回答
反对 回复 2023-03-03
  • 2 回答
  • 0 关注
  • 231 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信