

2.组件和state与props
source link: http://muyunyun.cn/blog/bfdttr5b/
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

组件即函数
在上一篇 JSX 和 Virtual DOM 中, 解释了 JSX 渲染到界面的过程并实现了相应代码, 代码调用如下所示:
本小节, 我们接着探究组件渲染到界面的过程。在此我们引入组件的概念, 组件本质上就是一个函数
, 如下就是一段标准组件代码:
<A name="componentA" />
是 JSX 的写法, 和上一篇同理, babel 将其转化为 React.createElement() 的形式, 转化结果如下所示:
可以看到当 JSX 中是自定义组件的时候, createElement 后接的第一个参数变为了函数, 在 repl 打印 <A name="componentA" />
, 结果如下:
注意这时返回的 Virtual DOM 中的 nodeName 也变为了函数。根据这些线索, 我们对之前的 render
函数进行改造。
至此, 我们完成了对组件的处理逻辑。
props 和 state 的实现
在上个小节组件 A 中, 是没有引入任何属性和状态的, 我们希望组件间能进行属性的传递(props)以及组件内能进行状态的记录(state)。
在上面这段代码中, 看到 A 函数继承自 Component。我们来构造这个父类 Component, 并在其添加 state、props、setState 等属性方法, 从而让子类继承到它们。
首先, 我们将组件外的 props 传进组件内, 修改 render 函数中以下代码:
实现完组件间 props 的传递后, 再来聊聊 state, 在 react 中是通过 setState 来完成组件状态的改变的, 在后面的 setState 优化 中会实现 setState 的异步逻辑, 此处简单实现如下:
此时虽然已经实现了 setState 的功能, 但是 document.getElementById('root')
节点写死在 setState 中显然不是我们希望的, 我们将 dom 节点相关转移到 _render 函数中:
自然地, 重构与之相关的 render 函数:
在 render 函数中分离出 _render 函数的目的是为了让 setState 函数中也能调用 _render 逻辑。完整 _render 函数如下:
让我们用下面这个用例跑下写好的 react 吧!
效果图如下:
至此, 我们实现了 props 和 state 部分的逻辑。
forceUpdate 的实现
当没有使用 setState 更新 state 状态时, 通常要结合 forceUpdate 一起使用, 例子如下:
这里要注意一个点当使用 forceUpdate() 时, shouldComponentUpdate() 会失效
, 下面我们来补充 forceUpdate() 的代码逻辑:
相应的在 render.js 中加上 allowShouldComponentUpdate 的判断条件:
组件即函数;当 JSX 中是自定义组件时, 经过 babel 转化后的 React.createElement(fn, ..) 后中的第一个参数变为了函数, 除此之外其它逻辑与 JSX 中为 html 元素的时候相同;
此外我们将 state/props/setState 等 api 封装进了父类 React.Component 中, 从而在子类中能调用这些属性和方法。
在下篇, 我们会继续实现生命周期机制, 如有疏漏, 欢迎斧正。
Recommend
-
17
React组件的state和props React 的数据是自顶向下单向流动的,即从父组件到子组件中,组件的数据存储在 props 和 state 中。实际上在任何应用中,数据都是必不可少的,我们需要直接...
-
7
Explain React State & Props Like I'm Five Mar 22, 2020 ・1 min read ...
-
8
How data is handled between Components in React (State vs Props) Reading Time: 3 minutesPrerequisites :
-
7
React hooks have been very promising solution for most of the coding issues that React framework had in old days. But for novice developers, it could be hard to understand. Especially if you are moving from old react to new. One of the main p...
-
7
V2EX › Vue.js Vue 组件 props 改变时,如何阻止多余的 render fanck0605 · 18 小时 0 分钟前...
-
16
作者:Matt Maribojoc译者:前端小智来源:stackabuse有梦想,有干货,微信搜索 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。本文 GitHub
-
10
vue组件的数据通信方式很多,本篇着重讲props/$emit,神助是v-model/.sync语法糖。 TL;DR props/$emit是父子组件最常用的通信方式,而v-model、.sync只是其语法糖...
-
7
什么是组件:用来实现局部功能的可复用代码片段 比如很多界面会用到“分页”功能,因此可以将它封装成独立的组件 这样用到分页的界面只需引入该组件而不必重新写代码 1 定义组件
-
9
Aglowid It Solutions Post...
-
8
1. React组件定义 1.1 函数组件(Function Components) 函数组件是一种简单的定义组件的方式,通过一个JavaScript函数来定义组件。函数接收一个props对象作为参数,并返回一个React元素作为输出。 1 <!-- 准备好一个“容器...
About Joyk
Aggregate valuable and interesting links.
Joyk means Joy of geeK