react组件为什么要大写?

在我们写 React 项目的时候,我们发现自定义的组件名一定要首字母大写,否则会报错,这是为什么呢?为什么React组件首字母必须大写?

我们在 React 中都是写的 JSX语法,从 JSX语法 到页面上的 真实DOM大概需要经历以下几个阶段:JSX语法 —> 虚拟DOM(JS对象) —> 真实DOM。

因为浏览器是无法识别JSX语法的,因此我们需要通过 babel 对JSX语法进行转义,然后才能生成虚拟DOM对象,而原因就是在这里。

babel在编译时会判断JSX中组件的首字母,当首字母为小写时,其被认定为原生 DOM标签,它的第一个变量被编译为字符串;当首字母为大写时,其被认定为自定义组件,它的第一个变量被编译为对象。

我们可以看一下babel是如何转义JSX语法的:

首先,我们发现,babel在进行转义JSX语法时,是调用了 React.createElement() 这个方法,这个方法需要接收三个参数:type, config, children。第一个参数声明了这个元素的类型。

对比上面两张图,图一中,我在创建自定义组件时没有首字母大写。 而 babel 在转义时把它当成了一个字符串 传递进去了;图二中,我把首字母大写了,babel 在转义时传递了一个变量进去。

问题就在这里,如果传递的是一个字符串,那么在创建虚拟DOM对象时,React会认为这是一个简单的HTML标签,但是这显然不是一个简单的HTML标签,因此去创建一个不存在的标签肯定是会报错的。

如果首字母大写,那么就会当成一个变量传递进去,这个时候React会知道这是一个自定义组件,因此他就不会报错了。

更多web前端开发知识,请查阅 HTML中文网 !!

以上就是react组件为什么要大写?的详细内容,更多请关注易知道|edz.cc其它相关文章!

推荐阅读