react入门基础

React 简介

React ------- 用于构建用户界面的JavaScript库/一个将数据渲染为HTML视图的开源JavaScript

React历史

【经典水时长/水字数】

Facebook开发,且开源

  1. 起初由Facebook的软件工程师 Jordan Walke 创建 膜拜 React 祖师爷】
  2. 2011年部署于 Facebooknewsfeed
  3. 2012年部署于 Instagram
  4. 20135月开源

. . . . . .【这里应该加句:我们的故事还在继续...】

为什么要学 React

【生活所迫】

  1. 原生JavaScript操作DOM繁琐、效率低(DOM-API操作UI
  2. 使用JavaScript直接操作DOM,浏览器会进行大量的重绘重排
  3. 原生JavaScript没有组件化编码方案,代码复用率低

【我JUBAO,老师你上vue也是这么说的】

React特点

【经典喝水案例,典典典典典典典典典典典典典典典典典典典】

  1. 采用组件化模式、声明式编程,提高开发效率及组件复用率
  2. React Native中可以使用React语法进行移动端开发【出现了,家人们】
  3. 使用虚拟DOM+优秀的diffing算法,尽量减少与真实DOM的交互【基操勿六】

React的基本使用

hello react 案例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>hello_react</title>
</head>
<body><!-- 准备好一个容器--><div id="test"></div><!-- 引入react库 --><script  src="../js/react.development.js"></script><script src="../js/react-dom.development.js"></script><!-- 引入babel,将jsx转换成js --><script src="../js/babel.min.js"></script><script type="text/babel">// 1.创建虚拟DOMconst VDOM = <h1>Hello,React</h1>// 2.渲染虚拟DOM到页面ReactDOM.render(VDOM,document.getElementById("test"));</script>
</body>
</html>

为什么使用JSX?

使用jsxjs创建虚拟DOM的方式对比【用js也能创建虚拟DOM?涨姿势了(烂梗)】

创建形式

<h1 id='title'><span>Hello,React</span>
</h1>

使用jsx

 <script type="text/babel">// 1.创建虚拟DOMconst VDOM = (<h1 id='title'><span>Hello,React</span></h1>)// 2.渲染虚拟DOM到页面ReactDOM.render(VDOM,document.getElementById("test"));</script>

使用js

api:React.createElement(标签名,标签属性,标签内容):用于创建虚拟dom

【原来是使用react内部的方法进行创建的】

 <script type="text/javascript">// 1.创建虚拟DOMconst VDOM = React.creatElement('h1',{id:'title'},React.creatElement('span',{},'Hello,React'))// 2.渲染虚拟DOM到页面ReactDOM.render(VDOM,document.getElementById("test"));</script>

总结:

jsxjsreact方面的语法糖【特别好,等于没说😒

虚拟DOM

虚拟DOM的本质就是object对象【还以为是啥高级玩意】

关于虚拟DOM【我有以下几点要说】

  1. 本质是Object类型的对象(一般对象)
  2. 虚拟DOM比较“轻”,真实DOM比较重,因为虚拟DOMReact内部在用,无需真实DOM上这么多的属性
  3. 虚拟DOM最终会转换成真实DOM,呈现到页面上

JSX语法规则

【前方高能】


//   创建虚拟DOM
const VDOM = (<div><h1>JSX语法规则</h1><div><h2>JSX是什么</h2><p>JSX是一种轻量级的标记语言,它允许你在HTML中定义一个组件,然后在页面中使用这个组件。</p><input type="text"/></div></div>
);
//  渲染虚拟DOM到页面
ReactDOM.render(VDOM, document.getElementById("test"));

规则:

  1. 定义虚拟DOM,不要写引号" "
  2. 标签中混入JS表达式时要用{}
  3. 样式的类名指定不要用class,要用className

【小尤,你是不是借鉴了】

  1. 内敛样式,要用style={{key:value}}的形式写
  2. 只有一个根标签
  3. 标签必须闭合

总结

最近在用vue3写项目,抽空看了点关于react的教学视频,感觉vue和react的相似之处还是挺多的,希望后面能够再接再厉把项目写好,把react学的更完善一些

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQLAIchemy 异步DBManager封装-01入门理解

前言 SQLAlchemy 是一个强大的 Python SQL 工具包和对象关系映射&#xff08;ORM&#xff09;系统&#xff0c;是业内比较流行的ORM&#xff0c;设计非常优雅。随着其2.0版本的发布&#xff0c;SQLAlchemy 引入了原生的异步支持&#xff0c;这极大地增强了其在处理高并发和异步…

AD高速板设计-DDR(笔记)

【一】二极管 最高工作频率&#xff1a; 定义&#xff1a;二极管的最高工作频率&#xff0c;即二极管在电路中能够正常工作的最高频率。常见的硅二极管的最高工作频率通常在几十MHz到几百MHz之间。在高频下&#xff0c;二极管可能无法有效地阻止反向电流&#xff0c;但也不会…

入门1-顺序结构

Hello,World! #include<iostream> using namespace std; int main(){ cout<<"Hello,World!"; return 0; }输出字符菱形 #include<iostream> using namespace std; int main() {// 上半部分菱形for(int i 1; i < 3; i){for(int j 1; j < 3…

智慧煤矿/智慧矿区视频汇聚存储与安全风险智能分析平台建设思路

一、建设背景 目前我国非常重视煤矿安全生产&#xff0c;并投入大量资金用于煤矿安全综合远程监控系统的研发。视频监控系统作为实现煤矿智能化无人开采的关键系统与煤矿安全生产的多系统协同分析与处理的关键信息源&#xff0c;在智慧矿山管控平台的建设中发挥着重要的作用。…

Linux学习之路 -- 进程篇 -- 环境变量

本文将介绍环境变量的相关内容&#xff0c;以及相关操作 目录 一、main 二、环境变量 1.为什么要有环境变量&#xff1f; 2.环境变量的特性以及命令行操作 <1>命令行操作&#xff1a; <2>特性&#xff1a; 一、main 介绍一下main函数的参数。 在一些教材上…

17. map和set的基本使用

1. 关联式容器 在初阶阶段&#xff0c;我们已经接触过STL中的部分容器&#xff0c;比如&#xff1a;vector、list、deque等&#xff0c;这些容器统称为序列式容器&#xff0c;因为其底层为线性序列的数据结构&#xff0c;里面存储的是元素本身。 那什么是关联式容器&#xff…

数据输入输出流(I/O)

文章目录 前言一、数据输入输出流是什么&#xff1f;二、使用方法 1.DataInputStream类2.DataOutoutStream类3.实操展示总结 前言 数据输入输出流也是将文件输入输出流打包后使用的对象。相比于文件输入输出流&#xff0c;数据输入输出流提供了简单易用的方法去操作不同类型的数…

Text2sql的一些技巧

最近看到了一篇关于text2sql的文章&#xff0c;以及一些论文。对使用模型做text2sql给了一些不错的建议。 参考文章&#xff1a;24年大模型潜力方向&#xff1a;大浪淘沙后的Text-to-SQL和Agent - 知乎 论文&#xff1a;https://arxiv.org/pdf/2403.09732.pdf 关于模型的建议 …

红外接收器的原理以及在STM32和51单片机中的应用

基本介绍&#xff1a; 红外接收器是一种用于接收红外线信号的装置&#xff0c;常见于各种电子设备中&#xff0c;如电视遥控器、空调遥控器等。它能够接收来自发射器发送的红外信号&#xff0c;并将其转换成电信号&#xff0c;以便设备进行相应的操作。红外接收器通常包含红外光…

AI大模型日报#0420:开源模型击败GPT-4、西湖大学蛋白质通用大模型、GPT的七条经验

导读&#xff1a; 欢迎阅读《AI大模型日报》&#xff0c;内容基于Python爬虫和LLM自动生成。目前采用“文心一言”生成了每条资讯的摘要。 标题: 开源模型打败GPT-4&#xff01;LLM竞技场最新战报&#xff0c;Cohere Command R上线 摘要: GPT-4在LLM竞技场被开源模型Cohere的…

9.Godot数组|遍历|静态变量|对象|调试

数组和字典的遍历 数组的概念 数组是一组数据的集合。在程序中负责批量处理数据。数组中的元素可以包括各个类型的数据&#xff0c;也可以对数组内数据类型进行限定。可以通过 数组名【数字】 的形式来访问数组元素&#xff0c;数字 0 代表数组的第一个元素。数组可以通过调用…

GPT状态和原理 - 解密OpenAI模型训练

目录 1 如何训练 GPT 助手 1.1 第一阶段 Pretraining 预训练 1.2 第二阶段&#xff1a;Supervised Finetuning有监督微调 1.3 第三阶段 Reward Modeling 奖励建模 1.4 第四阶段 Reinforcement Learning 强化学习 1.5 总结 2 第二部分&#xff1a;如何有效的应用在您的应…