当前位置: 首页 > news >正文

初识React: 基础(概念 特点 高效原因 虚拟DOM JSX语法 组件)

1.什么是React?

React是一个由Facebook开源的JavaScript库,它主要用于构建用户界面。React的特点是使用组件化的思想来构建界面,使得代码的可复用性和可维护性大大提高。React还引入了虚拟DOM的概念,减少了对真实DOM的直接操作,加快了渲染速度。

2..虚拟DOM:的高效主要体现:

  1. React使用虚拟DOM,将页面的渲染操作转化为JS对象的操作,通过比较新旧虚拟DOM的差异,只更新需要改变的部分,避免了对整个页面的重新渲染,提高了渲染效率。

  2. React使用组件化的思想,将页面分成多个小组件,每个组件都是独立的,只需要关注自己的业务逻辑,避免了操作全局变量和函数的问题,提高了代码的可维护性和可复用性。

  3. React提供了生命周期函数的概念,使得开发者可以在组件的不同状态下,执行不同的操作,避免了不必要的渲染和计算,提高了性能。

 

3.虚拟DOM:

     React是一个流行的JavaScript库,它被用于构建用户界面。React的核心概念之一就是虚拟DOM(Virtual DOM),它可以提高应用程序的性能和响应能力。本文将介绍React虚拟DOM的概念、语法和使用方法。

    1.概念

     虚拟DOM是一个轻量级的JavaScript对象树,它与浏览器中的真实DOM相对应。当React组件渲染时,React会使用虚拟DOM来描述要显示的元素及其属性。当数据发生变化时,React会重新生成虚拟DOM,并将其与之前的虚拟DOM进行比较和更新,最终将更新后的虚拟DOM渲染到真实DOM中。

    虚拟DOM的优势在于,它可以避免直接操作真实DOM,这样可以减少浏览器重绘次数,提高性能和响应能力。

      2.语法

      React中使用虚拟DOM的主要方式是通过JSX语法来描述要显示的UI元素。JSX是一种JavaScript语法扩展,它允许我们在JavaScript代码中嵌入HTML/XML代码。例如,下面是一个JSX表达式,它将一个``元素渲染到页面中:

const element = <h1>Hello, world!</h1>;
ReactDOM.render(element, document.getElementById('root'));

在这个例子中,我们使用JSX语法创建了一个虚拟DOM元素,并将其渲染到ID为“root”的DOM元素中。

除了JSX之外,React还提供了一些API来操作虚拟DOM。例如,我们可以使用React.createElement()方法来创建虚拟DOM元素:

const element = React.createElement('h1', {className: 'greeting'}, 'Hello, world!');
ReactDOM.render(element, document.getElementById('root'));

在这个例子中,我们使用React.createElement()方法创建了一个虚拟DOM元素,并将其渲染到ID为“root”的DOM元素中。

  1. 使用方法

在实际应用中,我们通常会使用React组件来描述应用程序的UI元素。每个React组件都是一个JavaScript类,它包含了渲染UI元素的代码和一些生命周期方法。

例如,下面是一个简单的React组件,它渲染了一个``元素,并使用props属性传递了一个名字:

class Greeting extends React.Component {render() {return <h1>Hello, {this.props.name}!</h1>;}
}
ReactDOM.render(<Greeting name="world" />, document.getElementById('root'));

在这个例子中,我们使用了一个React组件来渲染UI元素。在组件中,我们通过this.props来访问从父组件传递下来的数据。最后,我们将Greeting组件渲染到ID为“root”的DOM元素中。

总之,React虚拟DOM是React的核心概念之一,它可以提高应用程序的性能和响应能力。我们可以使用JSX语法和React提供的API来操作虚拟DOM,并且通常会将虚拟DOM与React组件一起使用来描述应用程序的UI元素。

4.JSX语法:

JSX是一种JavaScript的扩展语法,用于描述UI界面,它允许混合HTML标记和JavaScript代码,使得编写React组件更加简单、灵活和可读性更高。

JSX的语法规则:

  1. 类似于HTML,在JSX中可以使用尖括号来包含标签名称和属性。
  2. 属性需要用引号来引用字符串值,可以使用花括号来包含JavaScript表达式。
  3. 支持自闭合标签。
  4. JSX表达式需要在{}中使用,并可以嵌套使用。

例如:

import React from 'react';const App = () => {const name = 'World';return (<div><h1>Hello, {name}!</h1><p>This is a JSX example.</p><img src="example.png" alt="Example" /></div>);
};export default App;

在上面的代码中,我们使用JSX来创建一个简单的React组件,包含一些HTML标记和JavaScript表达式。我们定义了一个变量name,然后在h1标签中使用了这个变量,展示出了Hello, World!的结果。同时,我们也使用了图片标签<img>,展示了如何使用属性。

5.React组件:

 

React组件可以定义为一个JavaScript函数或类。以下是一个函数组件的示例代码:

import React from 'react';function Welcome(props) {return <h1>Hello, {props.name}!</h1>;
}

这个函数组件接收一个名为 props 的参数,并返回一个 h1 元素,其中包含传入的 props.name 值。

下面是一个类组件的示例代码:

import React, { Component } from 'react';class Welcome extends Component {render() {return <h1>Hello, {this.props.name}!</h1>;}
}

这个类组件继承自 React.Component 类,并实现了 render() 方法,该方法返回一个 h1 元素,其中包含传入的 this.props.name 值。

http://www.lryc.cn/news/110937.html

相关文章:

  • 自监督去噪:Neighbor2Neighbor原理分析与总结
  • 简单工厂模式(Simple Factory)
  • Agent:OpenAI的下一步,亚马逊云科技站在第5层
  • JMeter 4.x 简单使用
  • 深入NLTK:Python自然语言处理库高级教程
  • React 用来解析html 标签的方法
  • 【C++】做一个飞机空战小游戏(五)——getch()控制两个飞机图标移动(控制光标位置)
  • Flask 是什么?Flask框架详解及实践指南
  • C. Mark and His Unfinished Essay - 思维
  • Java的变量与常量
  • C# Blazor 学习笔记(6):热重置问题解决
  • 一百四十六、Xmanager——Xmanager5连接Xshell7并控制服务器桌面
  • 用Rust实现23种设计模式之 模板方法模式
  • python与深度学习(十三):CNN和IKUN模型
  • 题目:2283.判断一个数的数字计数是否等于数位的值
  • 任务14、无缝衔接,MidJourney瓷砖(Tile)参数制作精良贴图
  • 【uniapp APP如何优化】
  • uni-app——下拉框多选
  • 从excel中提取嵌入式图片的解决方法
  • python socket 网络编程的基本功
  • 【element-ui】form表单初始化页面如何取消自动校验rules
  • git 公钥密钥 生成与查看
  • 数据标注对新零售的意义及人工智能在新零售领域的应用?
  • 命令模式-请求发送者与接收者解耦
  • 【雕爷学编程】Arduino动手做(186)---WeMos ESP32开发板
  • 3、JSON数据的处理
  • 8月5日上课内容 nginx的优化和防盗链
  • 网络爬虫请求头中的Referer和User-Agent与代理IP的配合使用
  • RabbitMQ 生产者-消息丢失 之 场景分析
  • Hyper实现git bash在windows环境下多tab窗口显示