React入门 - 07(说一说 JSX 中的语法细节)

本章内容

目录

    • 1、js 表达式
    • 2、列表渲染
    • 3、条件渲染
    • 4、className
    • 5、jsx 中的样式处理
    • 6、dangeouslySetInnerHTML
    • 7、htmlFor
    • 8、使用 jsx 的注意事项

上一节内容我们完成了一个简单的TodoList案例。到现在为止我们已经知道怎么在 JSX中使用 “js 表达式”和”列表渲染“了,本节我们继续使用之前的工程项目来编写代码,补充在 React使用 JSX语法的一些细节。

1、js 表达式

  • JSX中使用表达式: { JS 表达式 }
  • 可使用的 js表达式有:

字符串、数值、布尔值、null、undefined、数组、对象
函数: add(1, 2)
js运算: 1+2、'abc'.split('') 等
...
  • 注意:if..elseswitch..case等是 js语句,不是表达式,不能出现在 {}
// App.js 文件中,注释之前的代码,换成以下代码,运行并打开浏览器观察显示结果import React, { Component } from 'react'
class App extends Component {constructor(props) {super(props)this.obj = {name: 'bob', age: 12}}// 加法add(a, b) {return a+b}// 减法minus (a, b) { return a-b}render() {return (<div className="App"><p>字符串: { 'str' }</p><p>数值: { 111 }</p><p>布尔值: { true ? 'true': 'false' }</p><p>null{ null }</p><p>undefined{ undefined }</p><p>数组: { [1, 2, 3, 4] }</p><p>对象: { this.obj.name} - {this.obj.age }</p><p>函数:{ this.add(1, 2)}, {this.minus(10, 1)}</p><p>计算: { 1+3333 }</p></div>)}}
export default App

在这里插入图片描述

2、列表渲染

  • TodoList案例中,我们已经了解到列表的渲染可以使用 map实现。
  • 渲染过程中需要指定 key, 这是 React内部用于性能优化的,我们后面会详细讲一下.
// App.js 文件中,注释之前的代码,换成以下代码,运行并打开浏览器观察显示结果import React, { Component } from 'react'class App extends Component {constructor (props) {super(props)this.userList = [{ name: 'bob', age: 22 },{ name: 'liii', age: 18 },{ name: 'mary', age: 19 },{ name: 'tom', age: 31 }]this.lower20List = this.userList.filter(item => item.age < 20)}render() {return (<div className="App"><p>展示用户列表数据:</p><ul>{this.userList.map((item, index) => <li>{item.name} --- {item.age}</li>)}</ul><p>展示20岁以下的用户数据</p><ul>{this.lower20List.map((item, index) => <li key={index}>{item.name} --- {item.age}</li>)}</ul></div>)}}export default App

在这里插入图片描述

3、条件渲染

官网这里详细介绍了在 JSX中如何进行条件渲染。具体的方式有:

  • 使用 if表达式语句、switch语句
  • 使用三目运算 ( condition ? a : b)
  • 使用 { condition && a }或者 {condtion || a}
// App.js 文件中,注释之前的代码,换成以下代码,运行并打开浏览器观察显示结果import React, { Component } from 'react'
function ShowScoreMessage(props){ // 注意组件函数的命名需要使用大驼峰方式if (props.score < 60) {return (<div><p>你的分数是: {props.score}</p><div>不及格!!!</div></div>)} else {return (<div><p>你的分数是: {props.score}</p><div>及格!!!</div></div>)}
}class App extends Component {contructor() {this.sex = 'male' // 1.1 定义一个性别的变量this.score = 99 // 2.1 定义一个score,根据 score 显示不同的提示组件this.isEdit = true // 3.1 定义一个isEidt 变量,用于表示当前是否是编辑状态}render() {return (<div>{/* 1.2 使用三目运算进行条件渲染 */}{this.sex==='male' ? ' 我是一个男孩': '我是一个女孩'}{ false ? <span>this is span</span> : null}{/* 2.2 使用 if 语句进行条件渲染 */}<ShowScoreMessage score={this.score}></ShowScoreMessage>{/* 3.2 使用 && 运算符显示数据 */}{ this.isEdit && '现在是编辑状态'}</div>)}
}
export default App

在这里插入图片描述

4、className

  • 在传统的前端编程中,如果想给一个 HTML元素添加类名,只需要给其 class属性进行赋值即可

  • 但是在 ReactJSX语法里,如果想给一个 HTML元素赋值类名,必须使用 className。如果使用 class关键字,React 会认为它是 E6中的类。为了避免歧义,React建议我们将 HTML属性 class改写成 className.

  • 当然了,如果你硬要使用 class来添加类名,确实能生效,但是仔细观察会发现浏览器的控制台会有个错误警告

/* App.css 文件*/
.p1 {color: #f00;
}.p2 {color: aqua;
}
// App.js 文件中,注释之前的代码,换成以下代码,运行并打开浏览器观察显示结果import React, { Component } from 'react'
import './App.css'class App extends Component {render() {return (<div>{/* 你会发现使用 class 也生效,就是控制台会出现错误警告 */}<p class="p1">这是一个class 为 p1 的 p元素</p>{/* 建议使用 className 来赋值类名 */}<p className="p2">这是一个class 为 p2 的 p元素</p>{/* 如果的类名是动态的,仍然可以结合jsx 的表达式+条件渲染 */}<p className={false ? 'p1' : ''}>这个p元素的类名是动态的</p></div>)}}export default App

在这里插入图片描述

5、jsx 中的样式处理

React中的样式处理,一般有三种方式:

  • 第一种方式是直接行内样式绑定
  • 第二种是将样式提取到一个变量中,再将变量绑定到 style属性上(常用)
  • 第三种是动态控制类名,不同类名里定义不同的样式
/* App.css 文件*/
.p1 {color: #f00;
}.p2 {color: aqua;
}
import React, { Component } from 'react'
import './App.css'class App extends Component {constructor(props) {super(props)this.styleObj = {color: '#f00',fontSize: '16px'}this.isP1 = false}render() {return (<div>{/* 1、行内样式 */}<p style={{color: '#0f0', border: '1px solid #ccc'}}>字体绿色,边框1px</p>{/* 2、将样式提取到一个变量中,然后赋值变量到 style 属性上 */}<p style={this.styleObj}>字体红色, 字号16px</p>{/* 3、使用动态类名来控制样式 */}<p className={this.isP1 ? 'p1': 'p2'}>类名为p2的样式</p></div>)}
}
export default App

在这里插入图片描述

6、dangeouslySetInnerHTML

  • 到现在为止,我们知道在 JSX中如果要渲染一个常规的字符串,可以将字符串赋值一个变量,然后直接使用 {}进行渲染。

  • 那现在假设一下,如果这个字符变量里存储的不是普通的字符串,而是一段 HTML,那要怎么才能正确显示这段 HTML呢?

  • 现在我们来实现一个需求:有个字符变量,内容为 <h1>这是一个 h1 标签</h1>, 希望在页面显示的结果是“一级标题”样式的 ”这是一个 h1 标签“,而不是 <h1> 这是一个 h1 标签</h1>

  • React中提供了 dangeouslySetInnerHTML属性,允许将 HTML插入到组件中。相当于 jsinnerHTMLdangeouslySetInnerHTML在使用时必须传递一个对象,该对象具有一个名为__html的属性,该属性包含您要插入到组件中的HTML字符串

  • 但要注意的是,就如同它的命名一样。它是危险的,由于不会转义,就意味着存在 XSS攻击或者其他安全问题

import React, { Component } from 'react'class App extends Component {constructor(props) {super(props)this.str = '<h1>这是一个 h1 标签</h1>'}render() {return (<div>{/* 直接渲染,你会发现界面显示的是: <h1>这是一个 h1 标签</h1>  */}{this.str}{/* 在 React 中可以使用 dangerouslySetInnerHTML 来实现直接将 HTML 插入到组件中 */}<p dangerouslySetInnerHTML={{__html: this.str}}></p></div>)}}export default App

在这里插入图片描述

7、htmlFor

  • 需求:有个可以输入姓名的输入框,要求点击”姓名“时,input框也可以获得焦点
  • 传统的做法是,使用 label元素包裹 ”姓名“,然后其for属性绑定inputid属性,这样就可实现点击"姓名"后input框获得焦点
  • 如果我们直接按照传统方式在 React中写,会发现效果虽然实现了,但是控制台会有个错误警告
  • React如果你要使用 labelfor,那么要将 for改写成 htmlFor
<label for="username">姓名</label>
<input id="username" value="bob" name="username" type="text" />
import React, { Component } from 'react'class App extends Component {render() {return (<div>{/* 功能实现了,但是控制台会出现一个错误警告  */}<label for="username">姓名: </label><input id="username" value="bob" name="username" type="text" />{/* 在 React 如果你要使用 label的 for ,那么要将 for 改写成 htmlFor */}<label htmlFor="username">姓名: </label><input id="username" value="bob" name="username" type="text" /></div>)}}export default App

在这里插入图片描述

8、使用 jsx 的注意事项

  • JSX必须有一个根节点,如果没有根节点则使用<></>(幽灵节点)或者 Fragment代替根节点
  • 所有标签必须形成闭合,双标签闭合或者单标签闭合都可
  • JSX语法更贴近js语法,属性名采用驼峰命名法,例:className,htmlFor
  • JSX支持多行(换行),如需换行,可使用()包裹

到此,本章内容结束!

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

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

相关文章

蓝桥杯 最长递增

输入 7 5 2 4 1 3 7 2 输出 3 思路 这个思路也很简单&#xff0c;后面大于前面&#xff0c;长度加一。当后面不大于前面的时候&#xff0c;就是一个新的递增序列了&#xff0c;递增序列的长度最小为1。 代码 #include <iostream> using namespace std; int main() {in…

Nginx初体验

文章目录 定义正向代理 & 反向代理安装与尝试 之前没怎么用过代理服务器Nginx&#xff0c;主要也是因为没有架构知识&#xff0c;根本不会去部署相关的机器。但是最近公司内部在调试的时候&#xff0c;经常用本机去充当Ngnix代理服务器&#xff0c;由于对这块知识掌握得还不…

leetcode—搜索二维矩阵II

编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性&#xff1a; 每行的元素从左到右升序排列。每列的元素从上到下升序排列。 示例 1&#xff1a; 输入&#xff1a;matrix [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,13,14,17,2…

【计算机网络】网络层——详解IP协议

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【网络编程】 本专栏旨在分享学习计算机网络的一点学习心得&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 &#x1f431;一、I…

第29集《佛法修学概要》

丁三、声闻乘 分二&#xff1a;戊一、释义&#xff1b;戊二、四谛法&#xff1b;戊三、结示 请大家打开讲义第八十二页。我们看丁三&#xff0c;声闻乘。 在祖师大德的判教当中&#xff0c;把我们整个大乘的成佛之道分成了三个部分&#xff1a;第一个是安乐道&#xff0c;第…

【链路层】点对点协议 PPP

目录 1、PPP协议的特点 2、PPP协议的组成和帧格式 3、PPP协议的工作状态 目前使用得最广泛的数据链路层协议是点对点协议PPP(Point-to-Point Protocol)。 1、PPP协议的特点 我们知道&#xff0c;互联网用户通常都要连接到某个 ISP 才能接入到互联网。PPP 协议就是用户计算机…

全罐喂养是什么意思?适合猫咪全罐喂养的猫罐头推荐

猫咪全罐喂养的风一直挺大的&#xff0c;但是有好多养猫人一直不知道全罐喂养是什么意思&#xff0c;作为铲龄6年的宠物店店长&#xff0c;从早几年就开始全罐喂养了&#xff0c;对各个品牌的猫罐头也都很熟悉。 作为铲屎官&#xff0c;我们都想要给我猫猫吃的更好&#xff0c…

[足式机器人]Part2 Dr. CAN学习笔记-Advanced控制理论 Ch04-16 Robust Controller非线性鲁棒控制器

本文仅供学习使用 本文参考&#xff1a; B站&#xff1a;DR_CAN Dr. CAN学习笔记-Advanced控制理论 Ch04-16 Robust Controller非线性鲁棒控制器 1. Slide Control 滑膜控制2 High Gain High Frequency3. 三种鲁棒控制器的比较如何分析控制器 Robust Control : tp achieve rob…

鸿蒙开发笔记(九):渲染控制,if/else,ForEach,LazyForEach

ArkUI通过自定义组件的build()函数和builder装饰器中的声明式UI描述语句构建相应的UI。在声明式描述语句中开发者除了使用系统组件外&#xff0c;还可以使用渲染控制语句来辅助UI的构建&#xff0c;这些渲染控制语句包括控制组件是否显示的条件渲染语句&#xff0c;基于数组数据…

【代码随想录05】242.有效的字母异位词 349. 两个数组的交集 202. 快乐数 1. 两数之和

目录 242.有效的字母异位词题目描述做题思路参考代码 349. 两个数组的交集题目描述做题思路参考代码 202. 快乐数题目描述做题思路参考代码 1.两数之和题目描述参考代码 242.有效的字母异位词 题目描述 给定两个字符串 s 和 t &#xff0c;编写一个函数来判断 t 是否是 s 的字…

父组件中 arr.push改变数组,但是子组件监听不到 arr 的变化

目录 一、问题 二、解决方法 三、总结 tiips:如嫌繁琐&#xff0c;直接移步总结即可&#xff01; 一、问题 1.真是奇怪呀&#xff0c;一般来说通过 push方法改变 数组&#xff0c;是一定会有响应式的&#xff0c;那就可以监听到变化。但是我今天却遇到了一件奇怪的事情。在…

k8s创建资源对象过程

我们都知道&#xff0c;K8S中一切皆资源&#xff0c;在使用K8S时&#xff0c;所有的pod或者controller都是通过yaml文件进行创建的。 那么接下来&#xff0c;就和大家一起看一下K8S是如何创建资源的。 创建资源对象的过程 Deployment是一种常见的资源对象。在Kubernetes系统…

高精度算法笔记·····························

目录 加法 减法 乘法 除法 高精度加法的步骤&#xff1a; 1.高精度数字利用字符串读入 2.把字符串翻转存入两个整型数组A、B 3.从低位到高位&#xff0c;逐位求和&#xff0c;进位&#xff0c;存余 4.把数组C从高位到低位依次输出 1.2为准备 vector<int> A, B, …

考研机试题收获——高精度进制转换

代码的第一遍真的很重要&#xff0c;在第一次打的时候尽量把问题思考全面&#xff0c;不要漏打少打&#xff0c;尽量不要留bug给之后de。 一、基础方面 一、处理输出的结束问题 scanf和cin默认都不会读取空格 ①scanf()&#xff1a;如果从文件中读取数据&#xff0c;当scanf()…

小红书达人投放策略分析,品牌方必看

小红书已经成为品牌营销的重要战场&#xff0c;达人投放作为小红书营销的核心环节&#xff0c;其策略的精准与否直接关系到营销效果的好坏。本文伯乐网络传媒将对小红书达人投放的重要性、投放策略以及监测与优化进行深入探讨&#xff0c;以期为品牌提供更具实操性的营销建议。…

Python(36):调试过程中遇到的问题记录

错误1&#xff1a;TypeError: object of type NoneType has no len() 原因&#xff1a;这个错误是因为我们试图迭代那个不可迭代的对象。 原来方法&#xff1a;for i in rlen(data_list) 解决办法&#xff1a; for i in range(len(data_list)): 在循环中使用 range() 函数解决了…

Vue入门六(前端路由的概念与原理|Vue-router简单使用|登录跳转案例|scoped样式|混入(mixin)|插件)

文章目录 前要&#xff1a;前端路由的概念与原理1&#xff09;什么是路由2&#xff09;SPA与前端路由3&#xff09;什么是前端路由4&#xff09;前端路由的工作方式 一、Vue-router简单使用1&#xff09;什么是vue-router2) vue-router 安装和配置的步骤① 安装 vue-router 包②…

Chrome 浏览器插件 cookies API 解析

Chrome.cookie 前端开发肯定少不了和 cookie 打交道&#xff0c;此文较详细的介绍下 chrome.cookie 的 API 以及在 popup、service worker、content 中如何获取的 一、权限&#xff08;Permissions&#xff09; 如果需使用 Cookie API&#xff0c;需要在 manifest.json 文件…

信驰达科技参与《汽车玻璃集成UWB数字钥匙发展研究白皮书》编制工作

为进一步探索汽车数字钥匙技术路线及开发思路&#xff0c;中国智能网联汽车产业创新联盟&#xff08;CAICV&#xff09;、福耀玻璃工业集团股份有限公司联合发起了《汽车玻璃集成UWB数字钥匙发展研究白皮书》研究工作。 2023年12月20日&#xff0c;由中国智能网联汽车产业创新…

PLSQL 把多个字段转为json格式

PLSQL 把多个字段转为json格式 sql Select cc.bm, cc.xm, json_arrayagg(cc.hb) jgFrom (Select aa.bm, aa.xm, json_object(aa.ksbh, aa.wjmc) hbFrom (Select 001 bm, 老六 xm, 0001 ksbh, 文具盒 wjmcFrom dual tUnion AllSelect 001 bm, 老六 xm, 0002 ksbh, 毛笔 wjmcFr…