在React项目中启用JSX语法

简介: 一、React项目示例二、JSX语法概念三、JSX本质四、启动JSX

React项目中启用JSX语法

 

目录:

一、React项目示例

二、JSX语法概念

三、JSX本质

四、启动JSX

 

 

一、React项目示例


1.创建index.js

//第一步:导入包

import React from 'react'

import ReactDoM from 'react-dom'

 

//第二步:创建虚拟DOM,构建好属性也可不在此构建

const mydiv = React.createElement( 'div', ( id: 'mydiv', title: 'div aaa' )"这是一个div元素’)

 

//第三步:调用render函数渲染

//调用ReactDOM,给一个DOM元素容器

ReactDoM . render(mydiv,document.getElementByid ( ' app ' ))

 

2.创建Index.html

<!DOCTYPE html><html lang "en">

<head>

<meta charset="UPE-8">

 

<title>Index首页</title>

<!-- <script src=" . ./ dist/main.js"></ script> -->

<!-- <script src=" / main .js"></script> -->

</ head>

<body>

<!--创建一个容器,将来渲染的虚拟DoM,会放到容器内显示--><div id="app ></div>

</ body>

</ html>

 

3. 运行项目

(1)  打开终端输入:

//使用npm

PS C:\Users\liulongbin\DesktopIreact-day1

代码\e1.webpack-base> npm run dev

 

(2)  弹出浏览器

image.png

 

回顾:什么时虚拟DOM?

JS对象的形式来表示DOMDOM之间的嵌套关系

 

HTML是最优秀的标记语言;

想要创建虚拟DOM,在页面上即使普通标签

 

官网封装代码:

Const mydiv=<div id=mydiv title=div aaa>这是一个div元素</div>

//类似于html标签语言,但不符合js代码规范

////注意:Js 文件中,默认不能写这种类似于HTM的标记;否则打包会失败;

const mydiv = React.createElement( 'div', ( id: 'mydiv', title: 'div aaa' )"这是一个div元素’)

效果一样

运行代码:

image.png

 

报错解决:

可以使用babel来转换这些Js 中的标签;

 

Const是一个简单的js对象,要么是一个复杂的js对象,在js中混合写入类似于HTTML的语法叫做JSX语法

 

 

二、JSX语法


1.概念

Js 中,混合写入类似于HTM的语法,叫做Jsx语法;

符合XML规范的JS语法

Jsx默认情况下浏览器不识别,可以把jsx语法转一下,通过babel工具转化为react,createElement语法来执行


2.本质

Jsx语法的本质,还是在运行的时候,被转换成了React.createElement 形犹来执行的

转化后通过API调用转换好之后运行在页面

 

3.启动jsx

1)安装babel插件

//安装两套包

运行

Cnpm i     babel-core   babel-loader     babel-plugin-transform-runtime -D

安装执行结果:

image.png

 

//两个语法:第一个预防env,第二个语法stage-0

运行cnpm i babel-preset-errv babel-preset-stage-e -D

安装执行结果:

image.png

打开webpack.config.js

添加:

//向外暴露一个打包的配置对象;因为 webpack是基于Node构建的;所以 webpack支持所有Node API 和语法

 

//webpack默认只能打包处理.js后缀名类型的文件,像.png,vue无法主动处理,所以要配置第三方loader

 

module.exports = {

mode: 'development', ll developmentproduction

// webpack 4.x中,有一个很大的特性,就是约定大于配置﹑约定,默认的打包入口路径是 src -> index.js

plugins: [

htm1P1ugin

] ,

//只要webpack遇见不能处理的东西,都会第一时间需要第三方模块

module: {//所有第三方模块的配置规则

Rules:{//第三方匹配规则,js或者jsx文件结尾的

//一个loader可以写为字符串,多个需要写为数组

//一定要添加exclude,否则整个项目是运行不起来的,会报错

{test:/\.js|jsx$/use:babel-loader’,exclude/node_modules/},//千万别忘记添加排除项

]

}

}

 

2)安装能够识别转换jsx语法的包

babel-preset-react

//把不认识的jsx语法转换为识别的语法

运行cnpm i babel-preset-react -D

 

(3)添加.babelrc]配置文件

 

Bebel项目文件一般放入项目的根目录下,命名为.babelrc,千万不要忘记添加.,要符合js语法规则,双引号且不能写注释

 

{

    //数组:放置所有语法

"presets" : [ "env", "stage-0" , "react"],

//数组:放置所有插件

"plugins": ["transform-runtime""]

//顺序没有差别

}

 

配置好bebal后运行代码:

image.png

实现嵌套:在index.js中添加代码:

Const mydiv=<div id=mydiv title=div aaa>这是一个div元素</div>

<h1>这是一个大大的H1</h1>

 

运行代码:

image.png

这样很方便,当时它不是直接把标签丢在页面,内部是转换的过程

相关文章
|
1月前
|
XML 前端开发 JavaScript
react之了解jsx
react之了解jsx
|
3月前
|
前端开发 JavaScript
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
本文介绍了在React项目中实现路由懒加载的方法,使用React提供的`lazy`和`Suspense`来优化项目首次加载的速度。通过将路由组件改为懒加载的方式,可以显著减少初始包的大小,从而加快首次加载速度。文章还展示了如何使用`Suspense`组件包裹`Switch`来实现懒加载过程中的fallback效果,并提供了使用前后的加载时间对比,说明了懒加载对性能的提升作用。
212 2
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
|
3月前
|
前端开发 JavaScript
学习react基础(3)_setState、state、jsx、使用ref的几种形式
本文探讨了React中this.setState和this.state的区别,以及React的核心概念,包括核心库的使用、JSX语法、类与函数组件的区别、事件处理和ref的使用。
76 3
学习react基础(3)_setState、state、jsx、使用ref的几种形式
|
3月前
|
前端开发 JavaScript Java
SpringBoot项目部署打包好的React、Vue项目刷新报错404
本文讨论了在SpringBoot项目中部署React或Vue打包好的前端项目时,刷新页面导致404错误的问题,并提供了两种解决方案:一是在SpringBoot启动类中配置错误页面重定向到index.html,二是将前端路由改为hash模式以避免刷新问题。
271 1
|
1月前
|
JavaScript 前端开发 容器
React零基础入门02--JSX语法基础
React零基础入门02--JSX语法基础
React零基础入门02--JSX语法基础
|
1月前
|
前端开发 JavaScript
手敲Webpack 5:React + TypeScript项目脚手架搭建实践
手敲Webpack 5:React + TypeScript项目脚手架搭建实践
|
2月前
|
XML 前端开发 JavaScript
React JSX
React 使用 JSX(一种类似 XML 的 JavaScript 语法扩展)来替代传统 JavaScript 编写 UI。JSX 使代码更简洁、执行更快且类型安全。例如,`&lt;h1&gt;Hello, world!&lt;/h1&gt;` 实际上是创建一个 React 元素,通过 `ReactDOM.render()` 渲染到 DOM。注意,JSX 中使用 `className` 替代 HTML 的 `class` 属性。
|
1月前
|
存储 前端开发 JavaScript
react之jsx编译原理
react之jsx编译原理
|
2月前
|
XML 前端开发 JavaScript
React JSX
10月更文挑战第7天
16 2
|
3月前
|
移动开发 前端开发
react项目配合diff实现文件对比差异功能
在React项目中,可以使用`diff`库实现文件内容对比差异功能。首先安装`diff`库,然后在组件中引入并使用`Diff.diffChars`或`Diff.diffLines`方法比较文本差异。通过循环遍历`diff`结果,可以生成不同样式的HTML元素来高亮显示文本差异。
142 1
react项目配合diff实现文件对比差异功能