react是不是组件化开发
本文小编为大家详细介绍“react是不是组件化开发”,内容详细,步骤清晰,细节处理妥当,希望这篇“react是不是组件化开发”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
站在用户的角度思考问题,与客户深入沟通,找到高平网站设计与高平网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:成都网站制作、网站建设、外贸网站建设、企业官网、英文网站、手机端网站、网站推广、国际域名空间、网络空间、企业邮箱。业务覆盖高平地区。
react是组件化开发;组件化是React的核心思想,可以开发出一个个独立可复用的小组件来构造应用,任何的应用都会被抽象成一颗组件树,组件化开发也就是将一个页面拆分成一个个小的功能模块,每个功能完成自己这部分独立功能。
本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。
react是组件化开发吗
react是组件化开发
1.组件化思想
当人们面对复杂问题的处理方式:
将复杂的问题进行拆解, 拆分成很多个可以处理的小问题
再将其放在整体当中,你会发现大的问题也会迎刃而解
其实上面的思想就是分而治之的思想:
分而治之是软件工程的重要思想,是复杂系统开发和维护的基石
而前端目前的模块化和组件化都是基于分而治之的思想
2.什么是组件化开发呢?
组件化也是类似的思想:
如果我们将一个页面中全部逻辑放在一起, 处理起来会变得非常复杂, 不利于后续管理及扩展
但如果我们将一个页面拆分成一个个小的功能模块, 每个功能完成自己这部分独立功能, 那么整个页面的管理和维护变得非常容易
我们需要通过组件化的思想来思考整个应用程序:
我们将一个完整的页面分成很多个组件
每个组件都用于实现页面的一个功能块
3.React的组件化
组件化是 React 的核心思想,前面我们封装的 App 本身就是一个组件
组件化提供了一种抽象,让我们可以开发出一个个独立可复用的小组件来构造我们的应用
任何的应用都会被抽象成一颗组件树
组件化思想的应用:
尽可能的将页面拆分成一个个小的、可复用的组件
这样让我们的代码更加方便组织和管理,并且扩展性也更强
4.React组件分类
React的组件相对于 Vue 更加的灵活和多样,按照不同的方式可以分成很多类组件:
根据组件的定义方式,可以分为:函数组件(Functional Component)和类组件(Class Component)
根据组件内部是否有状态需要维护,可以分成:无状态组件(Stateless Component)和有状态组件(Stateful Component)
根据组件的不同职责,可以分成:展示型组件(Presentational Component)和容器型组件(Container Component)
这些概念有很多重叠,但是它们最主要是关注数据逻辑和UI展示的分离:
函数组件、无状态组件、展示型组件主要关注UI的展示
类组件、有状态组件、容器型组件主要关注数据逻辑
React 创建组件
1.类组件
类组件的定义由如下要求:
组件的名称是大写字符开头 (无论类组件还是函数组件)
类组件需要继承自:
React.Component
类组件必须实现
render
函数使用
class
定义一个组件:constructor
是可选的,我们通常在constructor
中初始化一些数据this.state
中维护的就是我们组件内部的数据render()
方法是class
组件中唯一必须实现的方法
2.render函数的返回值
当
render
函数被调用时, 它会检查this.props
和this.state
的变化并返回以下类型之一
React元素
通常通过
JSX
创建例如:
会被
React
渲染为DOM
节点,\
会被React
渲染为自定义组件无论是
还是
均为React
元素数组或 fragments: 使得
render
方法可以返回多个元素Portals: 可以渲染子节点到不同的
DOM
子树中字符串或数值类型: 他们在
DOM
中会被渲染为文本节点布尔类型或null: 什么都不渲染
3.函数组件
函数组件是使用
function
来进行定义的函数, 只是这个函数会返回和类组件中render
函数一样的内容
函数组件的特点 (后面会讲hooks, 就不一样了)
没有生命周期, 也会被更新并挂载, 但是没有生命周期函数
没有 this (组件实例)
没有内部状态 (state)
读到这里,这篇“react是不是组件化开发”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注创新互联行业资讯频道。
标题名称:react是不是组件化开发
本文地址:http://scyanting.com/article/ijcogs.html