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

猿创征文|【React】组件化入门学习

目录

模块化

模块:

模块化:

组件化

组件:

组件化:

函数式组件

创建函数组件

Props参数传递(重点)

复合函数组件

类式组件

创建实例

用户自定义组件


模块化

模块:

理解:向外提供特定功能的js程序,一般就是一个js文件。

为什么:要拆成模块,随着业务逻辑增加,代码越来越多且复杂。

作用:复用js,简化js的编写,提高js运行效率。

模块化

当应用的js都以模块来编写,这个应用就是一个模块化的应用

组件化

组件:

理解:用来实现局部功能效果的代码和资源的集合(html/css/js/img等等)

为什么:要用组件,一个界面的功能复杂

作用:复用编码,简化项目编码,提高运行效率

组件化

当应用是以多组件的方式实现,这个应用就是组件化的应用

函数式组件

实质:一个 React 应用就是构建在 React 组件之上的。

函数组件:该函数是一个有效的 React 组件,因为它接收唯一带有数据的 “​props​”(代表属性)对象与并返回一个 React 元素。这类组件被称为“函数组件”,因为它本质上就是 JavaScript 函数。

创建函数组件

function HelloPerson(){

 return <h1>你好,我是函数式组件!</h1>;

}

ReactDOM.render(<HelloPerson/>,document.getElementById('root'));

说明:解析组件标签HelloPerson,发现组件是函数定义的,调用该函数,将返回的虚拟DOM,转为真实的DOM,随后呈现在页面上。

Props参数传递(重点)

function HelloPerson(person){

      console.log(this);//此处undefined babel编译后采取严格模式

  return (

  <ul>

  <li>姓名:{person.name}</li>

  <li>年龄:{person.age}</li>

  </ul>

  )

 }

ReactDOM.render(<HelloPerson name='张三' age={18}/>,document.getElementById('root'));

复合函数组件

 function GetName(props){
 return <li>姓名:{props.name}</li>
 }

 function GetAge(props){
 return <li>年龄:{props.age}</li>
 }

function HelloPerson(person){
 return (
 <ul>
 <GetName name={person.name}/>
 <GetAge age={person.age}/>
 </ul>

  )

  }

ReactDOM.render(<HelloPerson name='张三' age={18}/>,document.getElementById('root'));

类式组件

ES6 的 class 来定义组件,通过继承React.Component。解析流程如下:

React解析组件标签,找到了MyComponent组件。

发现组件是使用类定义的,随后new出来该类的实例,并通过该实例调用到原型上的render方法。

将render返回的虚拟DOM转为真实DOM,随后呈现在页面中。

创建实例

//创建类组件 1:继承react中的Component类 2:需要render

class Person extends React.Component{

 render(){

 return (

     <h1>你好,我是类式组件!</h1>

 )

 }

}

ReactDOM.render(<Person/>,document.getElementById("root"));

用户自定义组件

const element = <Person/>

ReactDOM.render(element,document.getElementById("root"));

相关文章:

  • 【Java牛客刷题】入门篇(03)
  • 数据库学习02
  • 神奇的卡尔曼滤波,目标追踪的福音
  • Web服务器配置与管理
  • [Linux]进程信号(信号入门 | 信号产生的方式 | 信号捕捉初识)
  • 【精通内核】CPU控制并发原理CPU中断控制内核解析
  • 【深度学习】Python 快速入门
  • 10、Java 方法的递归调用详解(递归调用的分析和案例:阶乘、斐波那契、猴子吃桃)
  • 【图解HTTP】HTTP首部
  • 还搞不明白“响应式编程”,那得看这篇
  • “蔚来杯“2022牛客暑期多校训练营10 EFI题解
  • fetch的简单使用
  • 程序员应了解的那些事(111)~进程、线程及堆栈关系
  • NTU 课程笔记:向量和矩阵
  • ElasticSearch Python API教程
  • 【跃迁之路】【477天】刻意练习系列236(2018.05.28)
  • C# 免费离线人脸识别 2.0 Demo
  • ES2017异步函数现已正式可用
  • express + mock 让前后台并行开发
  • Fastjson的基本使用方法大全
  • JavaScript异步流程控制的前世今生
  • Laravel核心解读--Facades
  • PHP 小技巧
  • RxJS 实现摩斯密码(Morse) 【内附脑图】
  • spring + angular 实现导出excel
  • Webpack 4x 之路 ( 四 )
  • 短视频宝贝=慢?阿里巴巴工程师这样秒开短视频
  • 给新手的新浪微博 SDK 集成教程【一】
  • 基于游标的分页接口实现
  • 来,膜拜下android roadmap,强大的执行力
  • 微信小程序设置上一页数据
  • 用Visual Studio开发以太坊智能合约
  • 智能合约Solidity教程-事件和日志(一)
  • ​香农与信息论三大定律
  • (附源码)ssm高校实验室 毕业设计 800008
  • (附源码)计算机毕业设计ssm高校《大学语文》课程作业在线管理系统
  • (论文阅读32/100)Flowing convnets for human pose estimation in videos
  • (求助)用傲游上csdn博客时标签栏和网址栏一直显示袁萌 的头像
  • (三) diretfbrc详解
  • (转)Linux NTP配置详解 (Network Time Protocol)
  • (转)负载均衡,回话保持,cookie
  • (转)总结使用Unity 3D优化游戏运行性能的经验
  • .NET Core 中插件式开发实现
  • .NET中 MVC 工厂模式浅析
  • @ConditionalOnProperty注解使用说明
  • [AIGC] 如何建立和优化你的工作流?
  • [EFI]Dell Inspiron 15 5567 电脑 Hackintosh 黑苹果efi引导文件
  • [I2C]I2C通信协议详解(一) --- 什么是I2C
  • [IE编程] IE8的SDK 下载
  • [IOI2018] werewolf 狼人
  • [Linux基础开发工具---vim]关于vim的介绍、vim如何配置及vim的基本操作方法
  • [MQ]常用的mq产品图形管理web界面或客户端
  • [NISACTF 2022]sign-ezc++
  • [nlp] 损失缩放(Loss Scaling)loss sacle
  • [node]Node.js 模块系统