react-2 jsx的学习

2024-06-19 03:28

本文主要是介绍react-2 jsx的学习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.什么是JSX?

概念:JSX就是Javascript和XML(HTML)的缩写,表示在js代码中编写HTML模板结构,它是React中编写UI模板的方式,如下图就是jsx:
jsx
优势:1.HTML的声明式模板写法;2.JS的可编程能力

2.JSX的本质:

浏览器本身是不能识别jsx的,需要通过babel解析工具做解析之后才能在浏览器中运行。

JSX 是一种在 React 中使用的 JavaScript 扩展语法,它允许我们以类似 HTML 的方式编写 JavaScript。为了将 JSX 转换成 JavaScript,我们需要使用 Babel 这样的编译器

以下是一个简单的例子,展示了如何将 JSX 代码转换为 JavaScript:
JSX的代码:

const element = <h1>Hello, world!</h1>;

转换成 JavaScript 的代码:

const element = React.createElement("h1", null, "Hello, world!");

在实际的项目中,这个转换通常是自动进行的,通过配置 Babel,当你保存文件时,或者在构建应用时,Babel 会自动将 JSX 转换成 JavaScript。

3.JSX中使用JS表达式:

在jsx中可以通过大括号语法{}识别javascript中的表达式,比如常见的变量、函数调用、方法调用等

  1. 使用引号传递字符串
  2. 使用js变量
  3. 函数调用和方法调用
  4. 使用js对象

代码如下:

// 项目的跟组件
// 根组件APP--->被引入到入口文件index.js中 -->入口文件被渲染到public中的index.html的root节点上
const message = "this is a message";
function getName() {return "coco";
}
function App() {return (<div className="App">this is react 111a22pp{/* 使用引号字符串 */}{"我是引号字符串"}{/* 使用js中的变量 */}{message}{/* 使用函数 */}{getName()}{/* 使用方法调用 */}{new Date().getDate()}{/* 使用js对象,一般是在处理样式的时候使用 */}<div style={{ color: "red" }}>this is div</div></div>);
}export default App;

效果图片如下:
在这里插入图片描述

4.jsx中实现列表的渲染

语法:在JSX中可以使用原生JS中的map方法遍历渲染列表
map方法渲染列表
示例代码如下:

const list = [{ id: "1001", name: "react" },{ id: "1002", name: "vue" },{ id: "1003", name: "angular" },
];
function App() {return (<div className="App">this is App{/* 渲染列表 */}{/* map 循环那个结构 return 那个结构 */}{/* 注意事项:加上一个独一无二的key  字符串或者number 一般都是使用id */}{/* key的作用:react框架内部使用:提升更新性能的 */}<ul>{list.map((item) => (<li key={item.id}>{item.name}</li>))}</ul></div>);
}export default App;

5.JSX中实现条件渲染

1.简单的逻辑可以使用:
可以通过逻辑与运算符&&、三元表达式(?:)实现基础的条件渲染
示例代码如下:

// 项目的跟组件
// 根组件APP--->被引入到入口文件index.js中 -->入口文件被渲染到public中的index.html的root节点上
//  jsx实现条件渲染
// 在React中,可以通过 逻辑与运算符&&、三元表达式(?:)实现基础的条件渲染const isLogin = false;
function App() {return (<div className="App">this is App{/* 逻辑与 && */}{isLogin && <span>this is span </span>}{/* 三元表达式处理 */}{isLogin ? <span>this is 三元</span> : <span>loading....</span>}</div>);
}export default App;

2.复杂的条件渲染:
解决方案:自定义函数+if判断语句
示例需求:根据一个变量来控制三种不同的展示,代码如下:

// 项目的跟组件
// 根组件APP--->被引入到入口文件index.js中 -->入口文件被渲染到public中的index.html的root节点上
//  jsx实现条件渲染
// 在React中,可以通过 逻辑与运算符&&、三元表达式(?:)实现基础的条件渲染
const isShow = 2; //有三种状态1,2,3
function getShowData() {if (isShow === 1) {return <div>我是状态1</div>;} else if (isShow === 2) {return <div>我是状态2</div>;} else {return <div>我是状态3</div>;}
}
function App() {return (<div className="App">this is App{getShowData()}</div>);
}export default App;

这篇关于react-2 jsx的学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1073876

相关文章

CSS3 布局样式及其应用举例

《CSS3布局样式及其应用举例》CSS3的布局特性为前端开发者提供了无限可能,无论是Flexbox的一维布局还是Grid的二维布局,它们都能够帮助开发者以更清晰、简洁的方式实现复杂的网页布局,本文给... 目录深入探讨 css3 布局样式及其应用引言一、CSS布局的历史与发展1.1 早期布局的局限性1.2

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

CSS引入方式和选择符的讲解和运用小结

《CSS引入方式和选择符的讲解和运用小结》CSS即层叠样式表,是一种用于描述网页文档(如HTML或XML)外观和格式的样式表语言,它主要用于将网页内容的呈现(外观)和结构(内容)分离,从而实现... 目录一、前言二、css 是什么三、CSS 引入方式1、行内样式2、内部样式表3、链入外部样式表四、CSS 选

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Nginx部署React项目时重定向循环问题的解决方案

《Nginx部署React项目时重定向循环问题的解决方案》Nginx在处理React项目请求时出现重定向循环,通常是由于`try_files`配置错误或`root`路径配置不当导致的,本文给大家详细介... 目录问题原因1. try_files 配置错误2. root 路径错误解决方法1. 检查 try_f

在React聊天应用中实现图片上传功能

《在React聊天应用中实现图片上传功能》在现代聊天应用中,除了文字和表情,图片分享也是一个重要的功能,本文将详细介绍如何在基于React的聊天应用中实现图片上传和预览功能,感兴趣的小伙伴跟着小编一起... 目录技术栈实现步骤1. 消息组件改造2. 图片预览组件3. 聊天输入组件改造功能特点使用说明注意事项

一文详解如何在Vue3中封装API请求

《一文详解如何在Vue3中封装API请求》在现代前端开发中,API请求是不可避免的一部分,尤其是与后端交互时,下面我们来看看如何在Vue3项目中封装API请求,让你在实现功能时更加高效吧... 目录为什么要封装API请求1. vue 3项目结构2. 安装axIOS3. 创建API封装模块4. 封装API请求

全解析CSS Grid 的 auto-fill 和 auto-fit 内容自适应

《全解析CSSGrid的auto-fill和auto-fit内容自适应》:本文主要介绍了全解析CSSGrid的auto-fill和auto-fit内容自适应的相关资料,详细内容请阅读本文,希望能对你有所帮助... css  Grid 的 auto-fill 和 auto-fit/* 父元素 */.gri

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen