0

0

深入理解React JS:在HTML中正确加载和渲染JSX组件

霞舞

霞舞

发布时间:2025-12-02 12:00:09

|

466人浏览过

|

来源于php中文网

原创

深入理解React JS:在HTML中正确加载和渲染JSX组件

本文详细阐述了在学习react js时,如何解决javascript文件无法在html中正确加载并渲染react组件的问题。核心内容包括理解jsx在浏览器中运行所需的babel转译机制,以及如何根据react版本(17或18)选择正确的reactdom api。文章将指导读者正确配置html脚本标签、处理常见的cors错误,并提供示例代码,确保react应用能够顺利运行。

引言

对于初学React JS的开发者而言,直接在HTML文件中引入React库并通过浏览器运行JSX代码是一种常见的学习方式。然而,在这个过程中,经常会遇到JavaScript文件无法加载、页面空白或控制台报错等问题。这些问题通常源于对JSX转译机制和React不同版本API的误解。本教程旨在提供一套清晰的解决方案,帮助开发者顺利地在浏览器环境中运行React应用。

核心问题分析

当您尝试在HTML文件中直接运行包含JSX语法的JavaScript代码时,可能会遇到以下两个主要障碍:

  1. JSX转译: 浏览器本身不直接支持JSX语法。JSX需要被Babel等工具转译成普通的JavaScript函数调用(如React.createElement())后才能被浏览器解析执行。在开发环境中,通常会使用构建工具(如Webpack、Vite)配合Babel进行预编译。但如果直接在浏览器中引入,则需要babel-standalone库在运行时进行转译。
  2. React版本API兼容性: React 17和React 18在渲染组件的API上存在显著差异。如果不匹配相应的API,将导致渲染失败。

解决方案

为了确保您的React JS文件能够正确加载并渲染,请遵循以下步骤:

1. 引入必要的React库和Babel

在HTML文件的

或标签内,需要按顺序引入React、ReactDOM和babel-standalone的CDN链接。

立即学习前端免费学习笔记(深入)”;

  • React: 核心库,包含React组件的定义。
  • ReactDOM: 用于将React组件渲染到DOM中。
  • Babel Standalone: 在浏览器中实时转译JSX代码。

示例 HTML 结构:




    React JS 教程
     
    
    
    
    
    


    

注意事项:

  • crossorigin属性对于CDN加载的React库是推荐的,有助于错误报告。
  • babel-standalone必须在您的本地React脚本之前引入。
  • 将React应用的挂载点(如
    )放置在中。

2. 正确配置本地JavaScript脚本标签

这是最关键的一步。您的本地JavaScript文件(例如script.js)如果包含JSX语法,其

如果缺少type="text/babel",浏览器将尝试将JSX作为普通JavaScript解析,从而导致语法错误和页面空白。

3. 编写兼容React版本的JSX代码

React 17和React 18在组件渲染方式上有所不同。请根据您引入的React版本选择正确的API。

a. React 17 及更早版本:使用 ReactDOM.render()

WeShop唯象
WeShop唯象

WeShop唯象是国内首款AI商拍工具,专注电商产品图片的智能生成。

下载

如果您引入的是React 17或更早版本(例如react@17/umd/react.development.js),则应使用ReactDOM.render()方法。

示例 script.js (适用于 React 17):

// 确保HTML中引入的是 React 17
// 
// 

ReactDOM.render(
    

你好,React 17!

, document.getElementById("root") );

b. React 18 及更高版本:使用 ReactDOM.createRoot()

React 18引入了新的根API ReactDOM.createRoot(),以支持并发渲染等新特性。如果您引入的是React 18(例如react@18/umd/react.development.js),则必须使用此新API。

示例 script.js (适用于 React 18):

// 确保HTML中引入的是 React 18
// 
// 

const rootElement = document.getElementById("root");
const root = ReactDOM.createRoot(rootElement); // 创建根

root.render(
    

你好,React 18!

// 渲染组件 );

如果您在React 18环境中使用ReactDOM.render(),控制台会显示警告或错误信息,提示您使用createRoot。

常见问题与注意事项

  1. CORS 策略错误 (Access to XMLHttpRequest ... blocked by CORS policy): 当您直接通过浏览器打开本地文件系统中的HTML文件(例如file:///D:/Ventures/React%20tutorial/index.html)时,babel-standalone在尝试加载script.js进行转译时,可能会因为浏览器的安全策略(CORS)而失败。 解决方案: 避免直接打开file://路径。请使用一个本地开发服务器来提供您的HTML文件。VS Code用户可以安装“Live Server”扩展,右键点击HTML文件选择“Open with Live Server”,它会在http://127.0.0.1:5500/这样的地址启动一个本地服务器,从而避免CORS问题。

  2. Babel 警告 (You are using the in-browser Babel transformer...): 当您使用babel-standalone时,控制台可能会出现此警告。这表明您正在浏览器中实时进行代码转译,这在生产环境中效率低下且可能影响性能。 建议: 在实际项目开发中,应使用构建工具(如Create React App、Vite、Next.js等)进行预编译,将JSX在部署前就转译为普通JavaScript。babel-standalone主要适用于学习和快速原型开发。

  3. 文件路径确认: 确保您的script.js文件与HTML文件位于同一目录下,或者在src属性中提供了正确的相对或绝对路径。

  4. 调试技巧:

    • 始终打开浏览器的开发者工具(F12),检查“Console”选项卡是否有错误信息。
    • 检查“Network”选项卡,确保所有JavaScript文件(包括React、ReactDOM、Babel和您的script.js)都已成功加载,且状态码为200。如果script.js的类型显示为xhr而不是script,这通常是CORS错误的表现。

总结

在HTML中直接加载和渲染React JSX组件,需要特别注意Babel的转译机制和React版本对应的渲染API。通过正确引入babel-standalone并为本地脚本设置type="text/babel",以及根据React 17或React 18选择ReactDOM.render()或ReactDOM.createRoot(),您可以有效地解决常见的加载问题。同时,建议在本地开发时使用HTTP服务器,以规避CORS错误,并为未来的生产环境开发打下基础。

相关文章

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

557

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

374

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

754

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

478

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

454

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

1031

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

658

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

553

2023.09.20

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 21.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号