猿创征文|【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"));


相关文章
|
3月前
|
前端开发 JavaScript
React学习之——条件渲染
【10月更文挑战第16天】React 中没有像Vue中v-if这种指令。React 中的条件渲染和 JavaScript 中的一样,使用 JavaScript 运算符 if 或者条件运算符去创建元素来表现当前的状态,然后让 React 根据它们来更新 UI。
|
4月前
|
前端开发 JavaScript
学习react基础(3)_setState、state、jsx、使用ref的几种形式
本文探讨了React中this.setState和this.state的区别,以及React的核心概念,包括核心库的使用、JSX语法、类与函数组件的区别、事件处理和ref的使用。
91 3
学习react基础(3)_setState、state、jsx、使用ref的几种形式
|
4月前
|
前端开发
学习react基础(2)_props、state和style的使用
本文介绍了React中组件间数据传递的方式,包括props和state的使用,以及如何在React组件中使用style样式。
43 0
|
2月前
|
前端开发 JavaScript 定位技术
React 地图组件 Mapbox 入门指南
Mapbox 是一个强大的地图平台,提供丰富的地图数据和工具,支持多种开发语言和框架。本文介绍如何在 React 项目中使用 Mapbox,涵盖基础概念、安装配置、基本用法、常见问题及解决方法、高级用法等内容,并通过代码示例详细说明,帮助开发者提升地图应用的开发效率和用户体验。
105 2
|
2月前
|
前端开发 API UED
React 图片轮播 Carousel:从入门到进阶
本文介绍了在 React 中实现图片轮播(Carousel)的方法,从基础安装和配置 `react-slick` 开始,逐步讲解了常见问题如图片路径、性能优化、自定义样式和交互处理,以及高级话题如动态数据加载和响应式设计。通过详细示例,帮助开发者避免易错点,提升轮播图的用户体验。
44 3
|
2月前
|
监控 前端开发 JavaScript
React 静态网站生成工具 Next.js 入门指南
【10月更文挑战第20天】Next.js 是一个基于 React 的服务器端渲染框架,由 Vercel 开发。本文从基础概念出发,逐步探讨 Next.js 的常见问题、易错点及解决方法,并通过具体代码示例进行说明,帮助开发者快速构建高性能的 Web 应用。
101 10
|
2月前
|
前端开发 JavaScript 安全
学习如何为 React 组件编写测试:
学习如何为 React 组件编写测试:
43 2
|
3月前
|
资源调度 前端开发 JavaScript
React进阶学习
React进阶学习
20 1
|
3月前
|
前端开发 JavaScript 开发者
探索现代Web前端技术:React框架入门
【10月更文挑战第9天】 探索现代Web前端技术:React框架入门
|
3月前
|
前端开发 JavaScript 开发者
React 组件化开发最佳实践
【10月更文挑战第4天】React 组件化开发最佳实践
73 4