react | 自学笔记 | 持续更新

2024-09-04 14:36

本文主要是介绍react | 自学笔记 | 持续更新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

React自学速学笔记

  • 数据单向流动
  • 事件
    • 为什么上述例子,是onClick={()=>shoot("goal!")}而不是onClick{shoot("goal")}?
    • event对象
  • 条件渲染
    • if方法
    • &&
    • ?: 三元表达式

纯小白自学笔记,有不对的欢迎指正。

数据单向流动

  • 单向流动对应的其实就是双向流动。简单理解,就是数据在父子之间的流动方向。单向流动,表示数据由父流向子组件,双向就是父子之间都可以流动。
  • 但是这个单向流动是不是只能由父流向子,子组件无法改变父组件的东西呢?不是的,只是说一个设计理念而已。
  • 学过angular的话,会知道,在angualr中,可以通过@input/@output实现数据的双向流动。react中,则是通过prop实现单向流动。区别在哪儿?假设父组件要向子组件传递一个变量名为age,值为1的变量。在angular中,结构大概是
<--Parent.html->
<app-child [(v)]=age></app-child>

当你在child组件中更改age变量之后,parent中的age也会跟着被改变;而在react中,大概是

function Parent(){let age=1;return (<div><Child v={age}></div>)
}

当你在Child中更改之后,Parent中的age是不会跟着改变的。而且,也要注意,prop对象是只读的。当然也是有其他方法在react中实现双向通信的,回头再说。

事件

  • 注意语法 onClick 而不是 onclick
    在这里插入图片描述

为什么上述例子,是onClick={()=>shoot(“goal!”)}而不是onClick{shoot(“goal”)}?

  • 学过angular的知道,写事件的时候,是带括号的: (click)=shoot(“goal”)
  • react中: 不带参数: onClick={shoot}; 带参数 onClick={()=>shoot(“goal”)};容易看出,带参数,用匿名函数包了一层。原因就是,在react中,和js一样,你写()了,就代表函数执行了。也就是,你可以这么写onClick={shoot(“goal”)};只是说,这么些,不用等到用户点击按钮,组件加载的时候就执行了。 其实,拿onClick事件举例子,你在屏幕上点击了,react就会自动加一个括号,执行相关的函数,所以我们想要传递其他参数的时候,需要用匿名函数包裹一下,相当于点击之后会执行这个匿名函数,里面的函数就跟着执行了呗;实在不懂,你就看这个例子
  • 在这里插入图片描述

event对象

其实就这个结构onClick={(e)=>fun(e)};实际上你只能在匿名函数中传递e,要么你别传,要传就只能传e;否则就会报错
在这里插入图片描述假设多传递了,就会报错。所以你可以改成

onClick={(e)=>foo(e,otherParams)}

在这里插入图片描述

条件渲染

在angular中也会有条件渲染的场景,一般可能借助以下的语法糖来完成

*ngIf *ngSwitch *ngTemplateOutlet

react中也有常见的方法

  • if
  • &&
  • ?:
function App() {
}// 直接在App文件中写下面的jsx,模拟从其他文件引用两个不同组件
let C1 = () => (<div>component 1</div>);
let C2 = () => (<div>component 2</div>);export default App;

if方法

function App() {let displayC1 = true;if (displayC1) {return <C1></C1>;} else {return <C2></C2>}
}// 模拟从其他文件引用两个不同组件
let C1 = () => (<div>component 1</div>);
let C2 = () => (<div>component 2</div>);export default App;

&&

这个巧妙点就在于a&&b:a为真才去执行b,a为假,就不会去执行b了。
应用在react中be like:

function App() {let displayC1 = true;return (/*displayC1为真,以下只会显示C1*/<div>{displayC1 && <C1/>}{!displayC1 && <C2/>}</div>);
}// 模拟从其他文件引用两个不同组件
let C1 = () => (<div>component 1</div>);
let C2 = () => (<div>component 2</div>);export default App;

?: 三元表达式

function App() {let displayC1 = true;return (<div>{displayC1 ? <C1/> : <C2/>}</div>);
}// 模拟从其他文件引用两个不同组件
let C1 = () => (<div>component 1</div>);
let C2 = () => (<div>component 2</div>);export default App;

这篇关于react | 自学笔记 | 持续更新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

html 滚动条滚动过快会留下边框线的解决方案

《html滚动条滚动过快会留下边框线的解决方案》:本文主要介绍了html滚动条滚动过快会留下边框线的解决方案,解决方法很简单,详细内容请阅读本文,希望能对你有所帮助... 滚动条滚动过快时,会留下边框线但其实大部分时候是这样的,没有多出边框线的滚动条滚动过快时留下边框线的问题通常与滚动条样式和滚动行

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

使用Python和Tkinter实现html标签去除工具

《使用Python和Tkinter实现html标签去除工具》本文介绍用Python和Tkinter开发的HTML标签去除工具,支持去除HTML标签、转义实体并输出纯文本,提供图形界面操作及复制功能,需... 目录html 标签去除工具功能介绍创作过程1. 技术选型2. 核心实现逻辑3. 用户体验增强如何运行

CSS 样式表的四种应用方式及css注释的应用小结

《CSS样式表的四种应用方式及css注释的应用小结》:本文主要介绍了CSS样式表的四种应用方式及css注释的应用小结,本文通过实例代码给大家介绍的非常详细,详细内容请阅读本文,希望能对你有所帮助... 一、外部 css(推荐方式)定义:将 CSS 代码保存为独立的 .css 文件,通过 <link> 标签

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue

Vue中插槽slot的使用示例详解

《Vue中插槽slot的使用示例详解》:本文主要介绍Vue中插槽slot的使用示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、插槽是什么二、插槽分类2.1 匿名插槽2.2 具名插槽2.3 作用域插槽三、插槽的基本使用3.1 匿名插槽

springboot+vue项目怎么解决跨域问题详解

《springboot+vue项目怎么解决跨域问题详解》:本文主要介绍springboot+vue项目怎么解决跨域问题的相关资料,包括前端代理、后端全局配置CORS、注解配置和Nginx反向代理,... 目录1. 前端代理(开发环境推荐)2. 后端全局配置 CORS(生产环境推荐)3. 后端注解配置(按接口

Vue 2 项目中配置 Tailwind CSS 和 Font Awesome 的最佳实践举例

《Vue2项目中配置TailwindCSS和FontAwesome的最佳实践举例》:本文主要介绍Vue2项目中配置TailwindCSS和FontAwesome的最... 目录vue 2 项目中配置 Tailwind css 和 Font Awesome 的最佳实践一、Tailwind CSS 配置1. 安

CSS3 布局样式及其应用举例

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