趣谈 React 的由来
近期开始的了新的学习(react),
本人学习有个习惯,
喜欢去探索由来和历史,
俗称吃瓜(手动滑稽)
一般网上的视频教程只会教你怎么用
react
但是并不会告诉你react
是当初是怎么来的,为了解决哪些痛点。
首先我们先来看一段 js
原生代码。
这是一段很简单的代码,用于操作 result
的增减,
现在,
让我们来抽象的看待这个问题,
画个图来表示:
- 不管你使用原生
js
还是jq
都要通过dom提供的API
,经历先从页面取到内容,然后经过js
操作以后再填回去。 react
同学认为这太智障了,虽然简单,但是能不能砍掉上面的步骤(从dom取内容)或下面的步骤(填回内容)呢,从而更简便呢?- 于是
react
同学砍掉了上面的步骤(砍掉下面的步骤不现实,因为js将无法通知页面),直接在js
中生成HTML
然后自动页面中同步(用虚线表示),然后当数据更新时,react
将重新生成一个对象,再自动的去更新原来页面的元素,从而使得页面中的数据也是最新值。 - 这样一来事情就变得简单了,代码量减少一半,
js
再也不用去页面中取元素,只需再js
中生成填回页面中即可。从来不去取页面中的元素,只去填东西。react
就是在这种理念下诞生了。
接下里我们用这种理念重写一次上面的代码。
根据上图的操作在页面中加入一个 span
然后为了加个按钮(为了简化先在页面中手动增加)
目前代码有点粗糙,但是为了简单明了演示上图的理念。
- 在
js
中生成对象插入到页面中 - 更新数据时,重新在
js
中生成对象同步更新原来的页面元素
接着我们开始优化一下上图代码,并把按钮也放入 js
代码中:
但是炸一看这代码还是很傻*
,于是我们继续来 分三步 更层次优化代码
- 这个
React.creatElement
方法名字太长了,抽出 - 这些个变量只用过一次,那我们就可以跳过声明变量,直接使用
于是代码就变成了这个样子:
具有一双慧眼的你,应该也看的出来这样的代码很像一种东西把…
这也就是 react
最聪明的一点优化,
我们惊讶的发现,这样的 js
代码和 HTML
标签上并没有什么区别,
于是聪明的 react
同学诞生了另一个想法(JSX),我们能不能让用户写下面的代码,然后经过程序转换成上面的代码呢?
这样一来,最终的结果就是我们通过写下面的代码来替换(也就是等价于)上面的代码。
经过 react
同学一番折腾,JSX
语法上线了 (敲黑板,重点:我们并不是在写HTML代码,而是用HTML的形式来写JS代码)
Finally,代码变成了这样子(react
最终的样子)
本文完。
PS
我们改变过后的类似HTML
代码就是虚拟DOM
还有回答一些弱智问题
为什么我们在写JSX
的时候,绑定事件的时候函数名后面不带括号?
因为在一开始的时候我们在js
中写的是对象{onClick: fn}
,这里需要的fn是整个函数,如果写成{onClick: fn()}
,赋值给onClick
的就是函数的返回值。
插值?
jsx 中不需要 slot,都能用 props 代替,包括事件
props 继承和 vue 相比?
按照 js 的对象规则合并即可, {…props}
循环?
数组的操作方法
样式 class 早期不能使用?
class 是 js 的关键词,现在已经解决了这个问题