React简单了解

devtools/2024/12/22 19:21:10/

原理简化了解 

javascript">import React from "react"
import { createRoot } form "react-dom/client"const element = React.createElement('p',{id: 'hello'},'Hello World!'
)const container = document.querySelector('#root')
const root = createRoot(container)
root.render()

编写一个自定义的render函数,该函数接受“React元素”和对container的引用:

javascript">function render(reactElement, containerDOMElement) {// 创建一个DOM对象const domElement = document.createElement(reactElement.type)// 更新属性domElement.innerHTML = reactElement.children;for (const key in reactElement.props) {const value = reactElement.props[key];domElement.setAttribute(key, value);}// 添加为子节点containerDOMElement.appenChild(domElement)}const reactElement = {type: 'a',props: {href: 'https://wikipedia.org/',id: 'some-links','data-num': 20,},children: 'Read more on Wikipedia',
};const containerDOMElement =document.querySelector('#root');render(reactElement, containerDOMElement);

 expression slots

我们可以使用大括号 ( {} ) 创建expression slots,任何放在大括号之间的内容都将被视为纯 JavaScript,而不是字符串。

JSX 在编译时并不会检查expression solts是否有效!它只是将内容转发到纯 JS 输出,并不会做任何额外的事情。

javascript">import React from "react"
import { render } from “react-dom”const shopping_list = ["apple", "banana", "carrot"];const element = (<div>Purchase: {shopping_list.length}</div>
)const compliedElement = React.createElement("div",{},"Purchase: "shoppingList.length
)const root = document.querySelector("#root");// render(element, root)
render(compliedElement, root);

你会发现程序输出没有任何变化!

所以如果你在expression slot中做一些条件判断的语句,它会发生错误,但这错误并不是jsx不允许,而是javascript不允许。

javascript">import React from "react"
import { render } from “react-dom”const shopping_list = ["apple", "banana", "carrot"];const element = (<div>Purchase: {if ( shoppingList.length < 5) "Almost done!"}</div>
)const compliedElement = React.createElement("div",{},"Purchase: "if ( shoppingList.length < 5) "Almost done!"
)const root = document.querySelector("#root");// render(element, root)
render(compliedElement, root);

很显然,我们不能将这种条件判断语句这样放在函数的参数中。

HTML与JSX的区别

JSX 看起来像 HTML,但有一些根本的区别

 关键字的保留

JavaScript 有几十个“关键字”。关键字是具有内置功能的关键字。因为它们已经做了一些事情,所以我们不能在 JSX 中使用它们。

但有一个问题,就是 HTML 属性有时与 JavaScript 关键字重叠。

javascript">const element = (<div><label for="name">Name:</label><inputid="name"class="fun-input"/></div>
);

 如果我们将其编译成 JavaScript,我们会发现我们使用了两个保留字:for,class。

为了解决这个冲突,React 对这两个术语使用了细微的变化:

  • for改为 htmlFor
  • class更改为className
javascript">const element = (<div><label htmlFor="name">Name:</label><inputid="name"className="fun-input"/></div>
);

区分大小写的属性

在 JSX 中,我们的属性需要是“camelCase” ,这是有效的html:

javascript"><videosrc="/videos/cat-skateboarding.mp4"autoplay="true"
>

在 JSX 中,我们需要将“autoplay”中的“p”大写,因为“auto”和“play”是不同的词:

javascript">const element = (<videosrc="/videos/cat-skateboarding.mp4"autoPlay={true}//  ^ Capital “P”/>
);

style的应用 

html中我们可以这么写:

javascript"><article style="filter: var(--shadow-elevation-high)"></article>

但在jsx中肯定是不行的,需要如下所示:

javascript"><article style={ { filter: "var(--shadow-elevation-high)" } }></article>

我们需要往expression slots中传入一个对象。

还有jsx标签必须闭合、必须小写等等。 

空格陷阱 

javascript">import { createRoot } from 'react-dom/client';const daysUntilSantaReturns = 123;const element = (<div><strong>Days until Santa returns:</strong>{daysUntilSantaReturns}</div>
);const container = document.querySelector('#root');
const root = createRoot(container);
root.render(element);

如上代码显示的会是:returns:123,而不是returns: 123,粗体文本和数字之间没有空格。

为什么会这样呢?

让我们考虑一下这个 JSX 如何编译为 JavaScript

javascript">const element = React.createElement('div',{},React.createElement('strong',{},'Days until Santa returns:'),daysUntilSantaReturns
);

请记住, JSX 不会编译为 HTML,它会编译为 JavaScript。当执行该 JavaScript 时,它只会创建并附加两个 HTML 节点:

那么我们该如何解决呢?最常见的解决方案是在大括号中添加单个空白字符:

javascript"><div><strong>Days until Santa returns:</strong>{' '}{daysUntilSantaReturns}
</div>

然而在 HTML 中,每个空白字符(以及换行符!)都会产生一个可见的空格。例如,假设我们有 3 个并排的图像(请参见下面的代码游乐场)。默认情况下,HTML 将在它们之间使用单个空白字符来呈现它们。

当然,它还取决于布局方式。在 Flex布局 中,浏览器将忽略所有空格和缩进,就像 JSX 编译器一样。


 

ran


http://www.ppmy.cn/devtools/144456.html

相关文章

代码随想录刷题-数组

文章目录 1.二分查找1.答案2.思路3.扩展题目1.搜索插入位置1.答案2.思路 2.在排序数组中查找元素的第一个和最后一个位置1.答案2.思路 3.x 的平方根1.答案2.思路 4.有效的完全平方数1.答案2.思路 4.总结1.标准二分模板 2.移除元素1.答案2.思路3.扩展题目1.删除有序数组中的重复…

深入理解STL list erase

1、list erase后&#xff0c;当前的迭代器失效&#xff0c;返回指向下一个节点的迭代器 #include<list> #include<iostream> #include<vector> using namespace std;int main() {list<int> ls;ls.push_back(1);ls.push_back(2);ls.push_back(3);list&…

如何在谷歌浏览器中设置家庭安全

在数字时代&#xff0c;保护家庭成员尤其是儿童的网络安全变得尤为重要。谷歌浏览器提供了一些实用的功能来帮助家长管理孩子的上网行为。本文将详细介绍如何在谷歌浏览器中设置家庭安全&#xff0c;包括启用加速访问模式、管理存储权限以及使用地址栏快捷搜索技巧。&#xff0…

在 Ubuntu 上安装 Muduo 网络库的详细指南

在 Ubuntu 上安装 Muduo 网络库的详细指南 首先一份好的安装教程是非常重要的 C muduo网络库知识分享01 - Linux平台下muduo网络库源码编译安装-CSDN博客 像这篇文章就和shit一样&#xff0c;安装到2%一定会卡住&#xff0c;如果你不幸用了这个那真是遭老罪了 环境&#xf…

文件,IO流

目录 一 java 1. IO流 1&#xff09;输入输出&#xff08;以程序的视角判断 &#xff09; 1.1 IO流的分类 1&#xff09;字符流效率高于字节流 1.2 流和文件的关系 2. inputstream--字节输入流 2.1 fileinputstream 2.1.1常用方法&#xff1a; 1&#xff09;单个字符…

vscode的keil assistant 中搜索不到全局变量

搜不到 但是在包含的文件中输入 ../../../,就是全局搜索的结果 我的文件结构是&#xff1a;\Desktop\LVGL文件系统移植&#xff08;lvgl8&#xff0e;&#xff13;&#xff09;\Projects\MDK-ARM 盲猜是keil assistant 当前文件夹打开的时候是进入到了MDK-ARM文件夹层次&…

Python tkinter写的《电脑装配单》和 Html版 可打印 可导出 excel 文件

Python版 样图&#xff1a; 说明书&#xff1a; markdown # 电脑配置单使用说明书 ## 一、软件简介 电脑配置单是一个用于创建和比较两套电脑配置方案的工具软件。用户可以选择各种电脑配件,输入数量和价格,软件会自动计算总金额,并支持导出和打印配置单。 ## 二、主要功能 1. …

免登陆是什么?

‌免登陆‌是指用户在访问系统或应用时&#xff0c;无需输入用户名和密码即可直接使用某些功能或服务。这种机制主要通过记录用户的身份信息&#xff0c;并在后续访问时通过会话管理、Token认证等方式进行身份验证&#xff0c;从而提升用户体验并减少登录负担‌。 实现原理 ‌…