网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

react中组件名称必须大写的原因-创新互联

这篇文章主要介绍了react中组件名称必须大写的原因,具有一定借鉴价值,需要的朋友可以参考下。下面就和我一起来看看吧。

成都创新互联公司成立于2013年,我们提供高端网站建设公司成都网站制作网站设计、网站定制、营销型网站建设微信小程序开发、微信公众号开发、成都网站营销服务,提供专业营销思路、内容策划、视觉设计、程序开发来完成项目落地,为轻质隔墙板企业提供源源不断的流量和订单咨询。

react中组件名称的首字母必须要用大写。原因:React中使用JSX语法,但浏览器无法识别JSX语法,需通过babel对JSX语法进行转义;而如果组件的首字母为小写时,其会被认定为原生DOM标签,创建一个不存在的标签是会报错的。

react中组件名称必须大写的原因

react组件名称的首字母一定要用大写

错误的写法: 组件首字母没有大写

function clock(props){  
 return (
    

      

现在的时间是{props.date.toDateString()}

    

 ) }
错误的写法会导致页面无法显示内容且报错,但又可以通过f12查看到标签以一种比较奇怪的方式存在,

react中组件名称必须大写的原因

正确的写法:

function Clock(props){  
 return (
    

      

现在的时间是{props.date.toDateString()}

    

 ) }

那究竟是为什么呢?

JSX语法 向 真实DOM的转换

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

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

react中组件名称必须大写的原因
react中组件名称必须大写的原因


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

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

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

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

所以:

同理,上述错误的写法因为是小写,所以babel就把clock当作是标签生成了,而html中又没有这个元素,所以导致以一种比较奇怪的方式存在

react中组件名称必须大写的原因


以上就是react中组件名称必须大写的原因的详细内容了,看完之后是否有所收获呢?如果想了解更多相关内容,欢迎来创新互联网站建设公司,行业资讯!


网站标题:react中组件名称必须大写的原因-创新互联
文章链接:http://bjjierui.cn/article/ejjhd.html

其他资讯