React基础教程(二):React的基本使用

news/2024/11/19 10:33:37/

React基础教程(二):React的基本使用

1、HelloReact

1.1 引入react基础依赖包

注意点:①必须要在②之前引入在这里插入图片描述

	<!--    引入react核心库--><script src="../js/react.development.js"></script><!--    引入react-dom,用于支持react操作dom--><script src="../js/react-dom.development.js"></script><!--    引入babel,用于将jsx转为js--><script src="../js/babel.min.js"></script>

1.2 创建容器

<!--    准备容器-->
<div id="test"></div>

1.3 创建以及渲染虚拟DOM

<!--此处一定要写babel-->
<script type="text/babel">// 1、创建虚拟DOMconst virtualDOM = <h1>Hello World</h1>; /*此处一定不要写引号,因为不是字符串。这是JSX语法*/// 2、渲染虚拟DOMReactDOM.render(virtualDOM, document.getElementById("test"));
</script>

1.4 完整代码

这里一定不能写引号"",
错误写法:const virtualDOM = “<h1>Hello World</h1>”;
正确写法:const virtualDOM = <h1>Hello World</h1>;

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Hello React</title><!--    引入react核心库--><script src="../js/react.development.js"></script><!--    引入react-dom,用于支持react操作dom--><script src="../js/react-dom.development.js"></script><!--    引入babel,用于将jsx转为js--><script src="../js/babel.min.js"></script>
</head>
<body>
<!--    准备容器-->
<div id="test"></div>
<!--此处一定要写babel-->
<script type="text/babel">// 1、创建虚拟DOMconst virtualDOM = <h1>Hello World</h1>; /*此处一定不要写引号,因为不是字符串。这是JSX语法*/// 2、渲染虚拟DOMReactDOM.render(virtualDOM, document.getElementById("test"));
</script>
</body>
</html>

1.5 显示效果

在这里插入图片描述

2、创建虚拟DOM的两种方式

2.1 使用JSX创建虚拟DOM

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Hello React</title><!--    引入react核心库--><script src="../js/react.development.js"></script><!--    引入react-dom,用于支持react操作dom--><script src="../js/react-dom.development.js"></script><!--    引入babel,用于将jsx转为js--><script src="../js/babel.min.js"></script>
</head>
<body>
<!--    准备容器-->
<div id="test"></div>
<!--此处一定要写babel-->
<script type="text/babel">// 1、创建虚拟DOMconst virtualDOM = <h1 id={'title'}><span>Hello React</span></h1>; /*此处一定不要写引号,因为不是字符串。这是JSX语法*/// 2、渲染虚拟DOMReactDOM.render(virtualDOM, document.getElementById("test"));
</script>
</body>
</html>

2.2 使用JS创建虚拟DOM(一般不用

但是当想用JS实现上述JSX实现的代码的时候,就十分麻烦,因为还要用React.createElement创建一个span标签。这就体现了为什么React用jsx语法书写

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Hello React</title><!--    引入react核心库--><script src="../js/react.development.js"></script><!--    引入react-dom,用于支持react操作dom--><script src="../js/react-dom.development.js"></script><!--    引入babel,用于将jsx转为js--><!--  <script src="../js/babel.min.js"></script>-->
</head><!---->
<body>
<!--    准备容器-->
<div id="test"></div>
<!--此处一定要写babel-->
<script type="text/javascript">// 1、创建虚拟DOMconst virtualDOM = React.createElement('h1', {id: 'title'}, 'Hello React!')// 2、渲染虚拟DOMReactDOM.render(virtualDOM, document.getElementById("test"));
</script>
</body>
</html>

所以,纯JS方式一般不用

3、虚拟DOM与真实DOM

本质是Object类型的对象(一般对象)

在这里插入图片描述

虚拟DOM比较“轻”,真实DOM比较“重”。因为虚拟DOM是React内部使用,无需真实DOM上那么多属性。(见下图)

在这里插入图片描述

虚拟DOM最终会被转化为真实DOM,呈现在页面上。

代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Hello React</title><!--    引入react核心库--><script src="../js/react.development.js"></script><!--    引入react-dom,用于支持react操作dom--><script src="../js/react-dom.development.js"></script><!--    引入babel,用于将jsx转为js--><script src="../js/babel.min.js"></script>
</head>
<body>
<!--    准备容器-->
<div id="test"></div><div id="demo"></div>
<!--此处一定要写babel-->
<script type="text/babel">// 1、创建虚拟DOMconst virtualDOM = (<h1 id={'title'}><span>Hello React</span></h1>); /*此处一定不要写引号,因为不是字符串。这是JSX语法*/// 2、渲染虚拟DOMReactDOM.render(virtualDOM, document.getElementById("test"));console.log("虚拟DOM=", virtualDOM);console.log(typeof virtualDOM);console.log(virtualDOM instanceof Object);const trueDOM = document.getElementById('demo');console.log('真实DOM=', trueDOM);// debugger;
</script>
</body>
</html>

http://www.ppmy.cn/news/404541.html

相关文章

给你一棵二叉树的根节点 root,翻转这棵二叉树,并返回其根节点

public class TreeNode {int val;TreeNode left;TreeNode right;TreeNode(){}TreeNode(int val){this.val val;}public TreeNode(int val, TreeNode left, TreeNode right) {this.val val;this.left left;this.right right;} } /* 递归的进行翻转 保存原来的右子树*/ publi…

OCR识别系列之一-----场景文字识别

另一种方法应用比较广的就是深度学习方法&#xff0c;深度学习方法是将OCR识别划分为文字检测和文本识别部分 &#xff0c;这也是深度学习技术可以充分发挥功效的地方。使用比较广泛的网络结构是Differentiable Binarization CRNN。 Differentiable Binarization简称DB&#…

EasyDL OCR文字识别

这个功能还是挺吊的&#xff0c;应用场景也不少。 定制识别图片中的文字信息&#xff0c;结构化输出关键字段内容&#xff0c;极大提升OCR模型训练效率&#xff0c;满 足个性化卡证票据识别需求&#xff1b;支持公有云服务、私有化部署多种使用方式。 说白了就是一个图片里有…

利用OCR识别图像中的英文和文字

一、Tesseract—OCR简介 将图片翻译成文字一般称为光学文字识别&#xff08;Optical Character Recognition,OCR&#xff09;。可以实现OCR的底层并不多&#xff0c;目前很多库都是实用共同的几个底层OCR库&#xff0c;或者是在上面进行定制。 Tesseract是一个OCR库&#xff0…

超轻量级中文ocr,OcrLiteOnnx文字识别

原项目地址&#xff1a;https://github.com/benjaminwan/OcrLiteOnnx 本文是基于原项目编译好后的OcrLiteOnnx文字识别系统&#xff0c;可以实现提取图片中的文字及文字中心点坐标等功能。 相较于Tesseract这个OCR来说文字识别的准确度要高很多&#xff0c;识别速度也会快&…

c++初始化vector的几种方法

在C中&#xff0c;vector是一种动态数组&#xff0c;可以在运行时自由添加、删除元素。初始化vector是创建一个vector对象并为其分配内存空间的过程。以下是C中初始化vector的几种方法&#xff1a; 默认构造函数 使用默认构造函数创建一个空的vector&#xff0c;如下所示&…

OCR文字识别软件哪个好?7大文字识别软件

由于从各种文档中提取文本的需求非常普遍&#xff0c;许多办公软件或公司都提供了OCR工具。在本文中&#xff0c;我们为您推出了一系列功能强大且易于使用的最佳 OCR 软件。 什么是 OCR 软件&#xff1f; OCR 软件是一种程序或工具&#xff0c;可以使用光学字符识别技术识别数…

Android集成百度OCR图片文字识别——总结

近期由于工作内容的需要&#xff0c;我要给项目集成一个图片文字识别功能&#xff0c;据说百度的不错&#xff0c;所以今天写一个关于百度OCR的集成总结&#xff0c;以便以后再次使用不用去看官方文档。 首先肯定是要在百度管理平台注册账号并登录&#xff0c;然后照常去添加应…