React | React的JSX语法

news2025/1/12 18:09:06

✨ 个人主页:CoderHing

🖥️ Node.js专栏:Node.js 初级知识
🙋‍♂️ 个人简介:一个不甘平庸的平凡人🍬

💫 系列专栏:吊打面试官系列  16天学会Vue  11天学会React  Node专栏

🍀 格言: ☀️ 路漫漫其修远兮,吾将上下而求索☀️

👉 你的一键三连是我更新的最大动力!❤️


目录

一、认识JSX语法

认识JSX

为什么React选择了JSX

二、JSX的基本使用

JSX的使用

三、JSX的事件绑定

React事件绑定

this的绑定问题

事件参数传递

四、JSX的条件渲染

React条件渲染

五、JSX的列表渲染

React列表渲染

列表中的key

六、JSX的原理和本质

JSX的本质

createElement源码

虚拟DOM的创建过程

jsx -> 虚拟DOM -> 真实DOM

声明式编程


一、认识JSX语法

认识JSX

 

  • 这段element变量的声明右侧赋值的标签语法是什么呢?

    • 它不是一段字符串(因为没有使用引号包裹)

    • 它看起来是一段HTML元素,但是我们能在js中直接给一个变量赋值html吗?

    • 不可以,如果我们将type=“text/babel”去除掉,那么就会出现语法错误;

    • 这就是一段jsx语法

  • JSX是什么?

    • JSX是一种JavaScript的语法拓展(eXtension)也在很多地方称为JavaScript XML因为看起来像一段XML语法

    • 用于描述我们的UI界面,并且他可以可以和JavaScript融合在一起使用

    • 它不同于Vue中的模板语法,你不需要专门学习模板语法中的指令。如v-for,v-if

为什么React选择了JSX

  • React认为渲染逻辑本质上与其他UI逻辑存在内在耦合

    • UI需要绑定事件

    • UI中需要展示数据状态

    • 在某些状态发生改变时,又需要改变UI

  • 他们之间是密不可分,所以React没有将标记分离到不同的文件中,而是将他们组合在一起,这个地方就是组件(Component)

  • JSX其实就是嵌入到JavaScript中的一种语法;

  • JSX的书写规范

    • JSX的顶层只能有一个根元素,所以我们很多时候在外层包裹一个div元素(或者Fragment)

    • 为了方便阅读,通常会在jsx的外层包裹一个小括号()并且jsxk有进行换行书写

    • JSX中的标签可以是单标签也可以是双标签

      • 如果是单标签必须以/>结尾

二、JSX的基本使用

JSX的使用

  • jsx中的注释

  • jsx嵌入变量作为子元素

    • 当变量是Number,String,Array类型时,可以直接展示

    • 当变量是null,undefined,Boolean类型时,内容为空

      • 如果希望可以展示null,undefined,Boolean那么需要转成字符串

      • 如 toString,空字符串拼接,String(变量)等...

    • Object对象类型不能作为子元素(not valid as a React child)

  • jsx嵌入表达式

    • 运算表达式

    • 三元表达式

    • 执行一个函数

  • jsx绑定属性

    • 如元素都会有 title属性

    • img元素会有 src属性

    • a元素有 href属性

    • 元素需要绑定 class

    • 使用 内联样式style

三、JSX的事件绑定

React事件绑定

  • 如果原生DOM原有一个监听事件,如何进行操作?

    • 获取DOM原生,添加监听事件

    • 在HTML原生中,直接绑定onclick

  • 在React中如何操作呢?

    • React事件的命名采用小驼峰,而不是纯小写

    • 我们需要通过{}传入一个事件处理函数,这个函数会在事件发生时被执行;

this的绑定问题

  • 在事件执行后,我们需要获取当前类的对象中相关的属性,这个时候需要用到this

    • 如果直接打印this,会发现它是一个undefined

  • 为什么是undefined?

    • btnClick函数并不是我们主动调用的,而是当button发生改变时,React内部调用了btnClick函数

    • 而它内部调用时,并不知道如何绑定正确的this

  • 解决this问题

    • bind给btnClick显示绑定this

    • 使用ES6 class fields语法

    • 事件监听时传入箭头函数

 

事件参数传递

  • 在执行事件函数时,我们需要获取一些参数值,如 event对象,其他参数

  • 获取event对象

    • 很多时候我们需要拿到event对象做一些事情(阻止默认行为...)

    • 默认情况下,event对象有被直接传入,函数就可以获取到event对象

  • 获取更多的参数

    • 我们需要获取更多的参数时,我们最好的方式是传入一个箭头函数,主动执行的事件函数,并传入参数

 

四、JSX的条件渲染

React条件渲染

  • 某些情况下,界面的内容会根据不同情况显示不同内容,或决定是否渲染其部分内容

    • Vue中,会通过指令控制 v-if v-show

    • React中,所有的条件判断都和JavaScript代码一致

  • 常见的条件渲染方式有哪些?

  • 条件判断语句

    • 适合逻辑较多的情况

  • 三元运算符

    • 适合逻辑简单的情况

  • 与运算符&&

    • 适合条件成立,渲染某一组件,不成立,什么也不渲染

  • v-show效果

    • 主要控制display属性是否为none

 

五、JSX的列表渲染

React列表渲染

  • 在真实开发中,我们会从服务器请求到大量数据,数据以列表的形式存储

    • 如 歌曲 歌手 排行榜列表数据

    • 如 商品 购物车 评论列表数据

    • 如 消息 动态 联系人列表数据

  • 在React中并没有像Vue模板中的v-for指令,我们需要通过JavaScript代码的方式组织数据,转成JSX

    • 很多从Vue转到React的人非常不习惯,认为Vue更加的简洁

    • 但是React中的JSX正是因为和JavaScript无缝衔接,让它可以更加灵活

    • 另外React是真正可以提高我们编写代码能力的一种方式

  • 那么在React中如何展示列表呢?

    • 在React中,展示列表最多的方式是使用数组的map高阶函数

  • 很多时候我们在展示一个数组中的数据前,需要对它进行一些处理

    • 如 过滤掉一些内容: filter函数

    • 如 截取数组中一部分: slice函数

列表中的key

  • 我们发现在前面的代码中,都会报一个警告:

 

  • 这个警告是告诉我们需要在列表展示的jsx中添加一个key

    • key主要的作用是为了提高diff算法时的效率

六、JSX的原理和本质

JSX的本质

  • 实际上,jsx仅只是React.createElement(component,props,...children)函数的语法糖

    • 所有的jsx最终都会被转换成React.createElement的函数调用

  • createElement需要传递三个参数:

  • 参数一:type

    • 当前ReactElement的类型

    • 如果是标签元素,那么就使用字符串表示"div"

    • 如果是组件元素,那么就直接使用组件的名称;

  • 参数二:config

    • 所有jsx中的属性都在config中以对象的属性和值的性质存储

    • 如 传入className作为元素的class

  • 参数三:children

    • 存放在标签中的内容,以children数组的方式进行存储

    • 如果是多个元素怎么办呢? React内部有对它进行处理

虚拟DOM的创建过程

  • 我们通过React.createElement创建出来一个ReactElement对象:

  • 这个ReactElement对象有什么作用呢?为什么要创建他呢?

    • React利用ReactElement对象组成了一个JavaScript的对象树

    • JavaScript的对象树就是 虚拟DOM(Virtual DOM)

  • 如何查看ReactElement的树结构呢?

    • 可以将之前的jsx返回的结果进行打印

  • 而ReactElement最终形成的树结构就是Virtual DOM

jsx -> 虚拟DOM -> 真实DOM

jsx代码 -> ReactElement对象 -> 真实DOM

声明式编程

  • 虚拟DOM帮助我们从命令式编程转到了声明式编程的模式

  • React官方说:Virtual DOM是一种编程的理念

    • 在这个理念中,UI以一种理想化或者说虚拟化的方式保存在内存中,并且它是一个相对简单的JavaScript对象

    • 我们可以通过ReactDOM.render让 虚拟DOM 和 真实DOM同步起来,这个过程叫做协调(Reconciliation)

  • 这种编程的方式赋予了React声明式的API:

    • 只需要告诉React希望让UI是什么状态

    • React来确保DOM和这些状态是匹配的

    • 你不需要直接进行DOM操作,就可以从手动更改DOM,属性操作,事件处理中解放出来.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/429071.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

商医通项目总结

一、项目概述 简介 尚医通即为网上预约挂号系统,网上预约挂号是近年开展的一项便民就医服务,旨在缓解看病难、挂号难的就医难题。网上预约挂号全面提供的预约挂号业务从根本上解决了这一就医难题。随时随地轻松挂号,不用排长队 微服务项目…

【数据结构】-归并排序你真正学会了吗??

作者:小树苗渴望变成参天大树 作者宣言:认真写好每一篇博客 作者gitee:gitee 如 果 你 喜 欢 作 者 的 文 章 ,就 给 作 者 点 点 关 注 吧! 文章目录前言一、递归版本二、非递归版本三、总结前言 今天我们再来将一个…

亮剑「驾舱」产品矩阵,百度要做智能化「卷王」

2023年,汽车智能化开启新一轮加速度。 伴随着汽车行业变革从“电动化”的上半场进入“智能化”的下半场,中国正成为智能驾驶技术领域的引领者和汽车智能化的核心战场。 据高工智能汽车研究院发布的《2023-2025年中国智能汽车产业链市场数据预测报告》预…

用机器学习sklearn+opencv-python过计算型验证码

目录 生成计算型验证码图片 用opencv-python处理图片 制作训练数据集 训练模型 识别验证码 总结与提高 源码下载 在本节我们将使用sklearn和opencv-python这两个库过掉计算型验证码,图片示例如下。 生成计算型验证码图片 要识别验证码,我们就需要…

【计算机图形学】裁剪算法(Cohen-Sutherland算法 中值分割算法 Liang-Barsky算法)

一 实验目的 编写直线段、多边形裁剪算法熟悉Cohen-Sutherland算法、中值分割算法和Liang-Barsky算法的裁剪二 实验算法理论分析Cohen-Sutherland算法: 中值分割算法: 与CS算法一样,首先对直线段端点进行编码,并把线段与窗口的关…

java创建线程的方法

线程是程序的一种操作单元,在程序中,一个线程和另一个线程是同时存在的。它是一个程序的一部分,但是他又是独立的,它不会影响到另一个线程的执行。但是多个线程同时运行时,会对系统资源造成一定的消耗。 线程之间的竞争…

[Linux] 基础IO

🥁作者: 华丞臧. 📕​​​​专栏:【LINUX】 各位读者老爷如果觉得博主写的不错,请诸位多多支持(点赞收藏关注)。如果有错误的地方,欢迎在评论区指出。 推荐一款刷题网站 👉 LeetCode刷题网站 文…

SQL Server用户定义的函数(UDF)使用详解

SQL Server用户定义的函数一、背景知识1.1、用户定义函数的优点1.2、函数类型1.3、指引1.4、函数中的有效语句1.5、架构绑定函数1.6、指定参数二、创建用户定义函数2.1、限制和权限2.2、标量函数示例(标量 UDF)2.3、表值函数示例2.3.1、内联表值函数 &am…

leetcode26.删除数组中的重复项

1.原题目链接:力扣 2.题目: 3. 思路:使用两个指针:src与dst,刚开始均指向起始位置,如果src的值与dst值相同,src,如果src的值与dst的值不相同,dst,src的值赋值给dst,src,即两个指针比较,值不相同…

图像去模糊:MIMO-UNet 模型详解

本内容主要介绍实现图像去模糊的 MIMO-UNet 模型。 论文:Rethinking Coarse-to-Fine Approach in Single Image Deblurring 代码(官方):https://github.com/chosj95/MIMO-UNet 1. 背景 由于深度学习的成功,基于卷…

docker搭建linux网络代理

docker搭建linux网络代理 1.准备 config.yaml 配置文件(含订阅节点、规则,一般机场或者本地配置中含有) 在root下创建文件夹命名为clash。上传配置好的config.yaml至clash文件夹。 2.配置 端口: port: 7890 ; socks-port: 7891 运行局域网…

Python网络爬虫之HTTP原理

写爬虫之前,我们还需要了解一些基础知识,如HTTP原理、网页的基础知识、爬虫的基本原理、Cookies的基本原理等。本文中,我们就对这些基础知识做一个简单的总结。 🌟HTTP 基本原理 在本文中,我们会详细了解 HTTP的基本原…

医学图像分割之MedNeXt

论文:MedNeXt: Transformer-driven Scaling of ConvNets for Medical Image Segmentation ConvNeXt网络是一种借鉴Transformer的思想进行了改进实现的全卷积网络,其通过全卷积网络和逆向残差瓶颈单元的设计,可以实现比较大的空间感受野。本文…

【MySQL】聚合查询

目录 1、前言 2、插入查询结果 3、聚合查询 3.1 聚合函数 3.1.1 count 3.1.2 sum 3.1.3 avg 3.1.4 max 和 min 4、GROUP BY 子句 5、HAVING 关键字 1、前言 前面的内容已经把基础的增删改查介绍的差不多了,也介绍了表的相关约束, 从本期开始…

windows将exe或者bat封装成系统服务进行管理

NSSM介绍 NSSM(the Non-Sucking Service Manager)是Windows环境下一款免安装的服务管理软件,它可以将应用封装成服务,使之像windows服务可以设置自动启动等。并且可以监控程序运行状态,程序异常中断后自动启动,实现守护进程的功能…

和利时:自主可控 安全高效

4月13—15日,由易派客电子商务有限公司、中国石油和石油化工设备工业协会、北京长城电子商务有限公司共同主办的2023第二届易派客工业品展览会在苏州国际博览中心成功召开。本次展会以“绿色智造融通赋能”为主题,杭州和利时自动化有限公司(简…

Cesium:Particle Systems粒子系统

官网文档,点击此处查看。 粒子系统简述 粒子系统是一种用于模拟复杂物理效果的图形学技术,它是一系列小图片的集合,当这些小图片被放在一起查看时,会形成一种更为模糊的对象,例如:火苗、烟、天气或者烟花。 粒子系统效果在电影和游中是十分普遍的。例如:飞机失…

Spark 之 解析json的复杂和嵌套数据结构

本文主要使用以下几种方法: 1,get_json_object():从一个json 字符串中根据指定的json 路径抽取一个json 对象 2,from_json():从一个json 字符串中按照指定的schema格式抽取出来作为DataFrame的列 3,to_j…

【洋桃一号板】STM32F103CBT6标准库函数驱动TM1640点亮数码管

一、今天介绍如何使用STM32F103CBT6驱动TM1640点亮数码管,硬件用的洋桃开发板,点亮后效果如下,六个数码管依次显示0.1.2.3.4.5.6.7 硬件原理图如下,只用到了单片机的两个IO口即可实现上图的效果,该开发板上用的是PA11…

chapter-3 -数据库数据模型

以下内容来源于MOOC学习—原课程请见:数据库原理与应用 考研复习 概述 关系及关系模式 笛卡尔积 定义在一组域上的有序对的集合, 域是一组具有相同类型的集合,比如自然数,长度小于n的字符串结合等【比如int age】 从n个域的每…