React18 基础入门API、JSX语法糖

news2024/10/7 12:28:27

文章目录

  • 一、react的一次使用
    • react.development.js
    • react-dom.development.js
    • React.createElement()
  • 二、三个API
    • React.createElement()
    • ReactDOM.createRoot()
    • root.render() 渲染页面
  • 三、JSX(JavaScript Syntax Extension)、babel
    • babel
    • JSX使用注意事项

一、react的一次使用

react.development.js

react 是react核心库,只要使用react就必须要引入
下载地址:https://unpkg.com/react@18.0.0/umd/react.development.js

react-dom.development.js

react-dom 是react的dom包,使用react开发web应用时必须引入
下载地址:https://unpkg.com/react-dom@18.0.0/umd/react-dom.development.js

注意引用先后顺序 先引用react核心库,再引用react-dom

React.createElement()

用来创建一个react元素

  • 参数1:元素名(组件名)

  • 参数2:元素中的属性
    设置事件的时候 需要使用驼峰和箭头函数 {onClick:()=>{alert('123')}}
    class属性设置 需要使用className

  • 参数3:元素的子元素

    // 创建一个React元素
    const button = React.createElement('button', {
        type: 'button',
        className: 'hello',
        onClick: () => {
            alert('你点我干嘛')
        }
    }, '点我一下');

在这里插入图片描述

二、三个API

React.createElement()

  • React.createElement(type, [props], […children])
    • 用来创建React元素
    • React元素无法修改

ReactDOM.createRoot()

  • createRoot(container[, options])
    • 用来创建React的根容器,容器用来放置React元素

root.render() 渲染页面

  • root.render(element)
    • 当首次调用时,容器节点里的所有 DOM 元素都会被替换,后续的调用则会使用 React 的 DOM 差分算法(DOM diffing algorithm)进行高效的更新。
    • 不会修改容器节点(只会修改容器的子节点)。可以在不覆盖现有子节点的情况下,将组件插入已有的 DOM 节点中。
    // 创建第一个div
    const div = React.createElement('div', {}, '我是一个div', button);

    // 获取根元素
    const root = ReactDOM.createRoot(document.getElementById('root'));

    // 将元素在根元素中显示
    root.render(div);

	// 老版本的React中使用方法
	// ReactDOM.render(div, document.getElementById('root')); 

三、JSX(JavaScript Syntax Extension)、babel

React.createElement()语法糖

JSX 是 JavaScript 的语法扩展,JSX 使得我们可以以类似于 HTML 的形式去使用 JS。JSX便是React中声明式编程的体现方式。声明式编程,简单理解就是以结果为导向的编程。使用JSX将我们所期望的网页结构编写出来,然后React再根据JSX自动生成JS代码。所以我们所编写的JSX代码,最终都会转换为以调用React.createElement()创建元素的代码。

需要配合babel使用,babel转换jsx为react元素

babel

babel下载地址:https://unpkg.com/babel-standalone@6/babel.min.js

<head>
    <meta charset="UTF-8">
    <title>JSX</title>
    <script src="script/react.development.js"></script>
    <script src="script/react-dom.development.js"></script>
<!-- 引入babel -->
    <script src="script/babel.min.js"></script>
</head>

<body>
    <div id="root"></div>

    <!--设置js代码被babel处理-->
    <script type="text/babel">

        // 创建一个React元素 <button>我是按钮</button>
        // 命令式编程
        // const button = React.createElement('button', {}, '我是按钮');

        // 声明式编程,结果导向的编程
        // 在React中可以通过JSX(JS扩展)来创建React元素,JSX需要被翻译为JS代码,才能被React执行
        // 要在React中使用JSX,必须引入babel来完成“翻译”工作
        
        // const button = <button>我是按钮</button>; 
        // React.createElement('button', {}, '我是按钮');

        /*
        *   JSX就是React.createElement()的语法糖
        *   JSX在执行之前都会被babel转换为js代码
        * */
        const div = <div>
            我是一个div
            <button>我是按钮</button>
        </div>;

        const root = ReactDOM.createRoot(document.getElementById('root'));
        root.render(div);

    </script>
</body>

JSX使用注意事项

  1. JSX不是字符串,不要加引号
  2. JSX中html标签应该小写,React组件应该大写开头
  3. JSX中最外层有且只有一个根标签
  4. JSX的标签必须正确结束(自结束标签必须写/)
  5. 在JSX中可以使用{}嵌入表达式
  • 有值的语句的就是表达式
const name = '孙悟空';
const ele = <h1>Hello {name}</h1>;
const ele2 = <h1>Hello {孙悟空}</h1>;
const ele3 = <h1>1 + 1 = {1 + 1}</h1>;
  • {} 中也可以调用函数
function fn(){
    return '哈哈';
}const ele = <h1>{fn()}</h1>

没有返回值的语句,像if、for等语句是不能出现在JSX中的!但是在if、for等里边写JSX是可以的:

let ele;
let isLogin = true;
if(isLogin){
    ele = <h1>欢迎光临!</h1>;
}else{
    ele = <h1>请登录!</h1>
}
let eles = [];
for(let i=0; i<5; i++){
    eles.push(<h2>我是第{i}个h2</h2>);
}
  1. 如果表达式是空值、布尔值、undefined,将不会显示
  2. 在JSX中,属性可以直接在标签中设置
    • 注意:
    • class需要使用className代替
    • style中必须使用对象设置
    • style={{background:‘red’}}
<head>
    <meta charset="UTF-8">
    <title>JSX的注意</title>
    <script src="script/react.development.js"></script>
    <script src="script/react-dom.development.js"></script>
    <!-- 引入babel -->
    <script src="script/babel.min.js"></script>
</head>

<body>
    <div id="root"></div>

    <script type="text/babel">
        /*
        *   JSX的注意事项
        *       1. JSX不是字符串,不要加引号
        *       2. JSX中html标签应该小写,React组件应该大写开头
        *       3. JSX中最外层有且只有一个根标签
        *       4. JSX的标签必须正确结束(自结束标签必须写/)
        *       5. 在JSX中可以使用{}嵌入表达式
        *          - 有值的语句的就是表达式
        */
        const name = '孙悟空';
        function fn() {
            return 'hello';
        }
        const div1 = <div>
            {name} <br />
            {1 + 1} <br />
            {fn()} <br />
            {NaN} <br />
        </div>

        /*      6. 如果表达式是空值、布尔值、undefined,将不会显示
        *       7. 在JSX中,属性可以直接在标签中设置
        *           注意:
        *               class需要使用className代替
        *               style中必须使用对象设置
        *                   style={{background:'red'}}
        * 
        */
        const div2 = <div
            id="box"
            onClick={() => {
                alert('哈哈')
            }} className="box1"
            style={{ backgroundColor: "yellowgreen", border: '10px red solid' }}
        >
            我是一个div
        </div>;

在这里插入图片描述在这里插入图片描述

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

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

相关文章

mysql与磁盘的关系

1.如今一直在说mysql存储方式和磁盘的关系&#xff0c;但是现在都是硬盘存储啊 磁盘分为硬盘和软盘 硬盘结构&#xff08;机械硬盘和固态硬盘&#xff09;详解 硬盘的大小是使用"磁头数 x 柱面数 x 扇区数 x 每个扇区的大小 如下&#xff1a; 每个扇区的大小是固定的…

javaEE高阶---Spring MVC

一 : 什么是Spring MVC ? 1.1 概述 Spring MVC全称Spring Web MVC,又称为Spring Web,它是一个原始的基于Servlet API 的 web 框架.Q : 经典问题 : Spring/Spring Boot/Spring MVC 有什么区别 ? A : Spring&#xff0c;一般指代的是Spring Framework&#xff0c;它是一个开源…

业务数据分析-常见业务指标

目录 1、什么是指标&#xff1f; 2、以互联网电商数据为例分析常用的指标 3、如何选择指标 4、电商指标体系详细介绍 1、什么是指标&#xff1f; 我们说过分析的最终目的就是为了通过客观的数据去发现公司业务存在的问题&#xff0c;那怎么通过什么数据呢&#xff1f;业务…

连接MySQL问题的错题小集

目录 一. 连接不上数据库 踩坑 解决过程 二. Can‘t connect to MySQL server on ‘localhost:3306‘ (10061) 排查1&#xff1a;数据库没有启动 排查2&#xff1a;判断数据库是否存在 排查3&#xff1a;数据库没有启动 ​编辑 过程&#xff1a; 报错了&#xff0c;排…

12.Java 技术栈中间件优雅停机方案设计与实现全景图

Java 技术栈中间件优雅停机方案设计与实现全景图 本系列 Netty 源码解析文章基于 4.1.56.Final 版本 本文概要 在上篇文章 中笔者为大家详细介绍了 Netty 在处理连接关闭时的完整过程&#xff0c;并详细介绍了 Netty 如何应对 TCP 连接在关闭时会遇到的各种场景。 在连接关闭…

软件压力测试有哪些测试流程?软件测试报告收费情况

软件压力测试是一种基本的质量保证行为&#xff0c;它是每个重要软件测试工作的一部分。通过给软件系统不断施压&#xff0c;强制其在极限条件下运行&#xff0c;以观察软件系统可运行到哪种程度&#xff0c;从而发现系统性能缺陷。测试人员根据测试过程进行总结和分析&#xf…

[附源码]Python计算机毕业设计Django个性化产品服务管理系统论文

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…

电脑重装系统后序列号怎么查

最近很多网友都在问怎么看桌面操作系统序列号&#xff0c;我们安装系统的时候是需要知道&#xff0c;其实想要知道自己电脑的序列号非常简单的&#xff0c;网友们看看下面操作就知道了。 工具/原料&#xff1a; 系统版本&#xff1a;win10 型号&#xff1a;联想小新Air 13 Pro…

【矩阵论】4. 矩阵运算——广义逆——减号逆

4.5 减号逆 若 AAmnAA_{m\times n}AAmn​ 与 XXnmXX_{n\times m}XXnm​ &#xff0c;有 AXAAAXAAAXAA &#xff0c;则称 XXnmXX_{n\times m}XXnm​ 为A的减号逆(一号逆)&#xff0c;记为 XA−A(1)XA^{-}A^{(1)}XA−A(1) 全体 A−A^{-}A− 的集合记为 A{1}{X∣AXAA}A^{\{1\}}\…

【自然语言处理概述】百度百科数据爬取

【自然语言处理概述】百度百科数据爬取 作者简介&#xff1a;在校大学生一枚&#xff0c;华为云享专家&#xff0c;阿里云专家博主&#xff0c;腾云先锋&#xff08;TDP&#xff09;成员&#xff0c;云曦智划项目总负责人&#xff0c;全国高等学校计算机教学与产业实践资源建设…

氮化镓(GaN)功率半导体之预测

前言 氮化镓&#xff08;GaN&#xff09;是一种非常坚硬且在机械方面非常稳定的宽带隙半导体材料。由于具有更高的击穿强度、更快的开关速度&#xff0c;更高的热导率和更低的导通电阻&#xff0c;氮化镓基功率器件明显比硅基器件更优越。 氮化镓晶体可以在各种衬底上生长&…

充分利用自动化测试的 10 个最佳实践

你试过吃带壳的坚果吗&#xff1f;如果是&#xff0c;我想这不是一次非常成功的经历。 虽然大家都知道坚果是非常健康和有营养的。矛盾的是&#xff0c;许多公司在实施测试自动化时没有考虑细微差别。每个人都知道它对身体有好处&#xff08;就像吃坚果对我们健康有益一样&…

线上环境不要使用console.log,会导致页面卡顿,内存泄漏的原因

在我的这篇文章中分享了一个经验&#xff0c;就是vite打包之后会自动屏蔽所有的console.log打印的日志。 那么&#xff0c;在线上环境中不要使用 console.log 打印日志&#xff0c;已经成为共识&#xff0c;你知道是为什么么&#xff1f; 原因当然在于这个罪魁祸首 console 方…

深拷贝、浅拷贝的方法

目录 浅拷贝 深拷贝 与浅拷贝概念&#xff1a; 深浅拷贝出现的前提&#xff1a; 应用类型的数据&#xff08;对象和数组&#xff09; 深拷贝就是把目标对象里面的数据一个一个都复制下来&#xff0c;创建出一个一模一样的&#xff0c;存放地 址不一样&#xff0c;互不影响。…

【白嫖】如何底价续费服务器

目录 背景 问题 缓解方案 背景 现在各大云服务商的学生价服务器都已经关闭了&#xff0c;华为云、阿里云、百度云&#xff0c;以前都有学生价服务器&#xff0c;一年只要99。现在我找半天都没找到入口&#xff0c;而原价的一年得500块起步。。。 但是&#xff01;&#xff0…

MySQL事务详解

目录 引例 什么是事务 一个完整事务所具有的四大属性 为什么会出现事务 事务常见操作方式 事务隔离级别 为什么要存在隔离级别 一致性 引例 如下图&#xff0c;是一个火车售票系统&#xff0c;当客户端A发现还有一张票时&#xff0c;将票卖掉&#xff0c;还没执行更新…

C++实现UDP可靠传输(二)

声明&#xff1a;禁止以任何形式转载本文章。本文章仅供个人学习记录与交流探讨&#xff0c;文章中提供的思路只是一种解决方案&#xff0c;代码也并非完整代码&#xff0c;如有需要&#xff0c;请自行设计协议并完成编程任务。 食用本文章之前&#xff0c;推荐阅读&#xff…

RKMEDIA--VENC/VDEC使用

前面两篇已经介绍了VI和VO的使用&#xff0c;本章节来介绍rkmedia且也是瑞芯微平台重点部分&#xff1a;编解码。 目录 一、简介 二、编解码能力 三、编码 编码初始化&#xff1a; 在初始化VENC时需要注意几点&#xff1a; venc编码帧率控制&#xff1a; 编码添加osd位图…

软件设计师考试重点1 计算机组成与体系结构

软件设计师考试重点1 计算机组成与体系结构一、 数据的表示1. 进制转换2. 原码/反码/补码/移码3. 数值表示范围4. 浮点数的运算二、运算器与控制器1. 计算机结构2. 计算机五大组成部分&#xff1a;3. CPU组成部分&#xff1a;4. 控制器组成部分&#xff1a;5. 运算器组成部分&a…

如何构建一个自动化油田注水站监控系统?

一、应用背景 目前&#xff0c;在大部分的钻井平台中&#xff0c;维护油田注水站的工作状态主要通过人工方式进行&#xff0c;这种方式不仅作业效率低且对工人的经验有着较高要求。此外&#xff0c;油田注水站的工作环境恶劣&#xff0c;为了能够有效地掌握各个设备的工作状态…