博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
React as a UI Runtime(二、React元素和入口)
阅读量:6505 次
发布时间:2019-06-24

本文共 1374 字,大约阅读时间需要 4 分钟。

1、React元素

在宿主环境中,一个宿主实例是最小的单位(像DOM节点)。在React中最小的单位是React元素。

一个React元素就是一个描述宿主实例的Javascript对象。

// 用JSX语法糖对这个对象描述// {  type: 'button',  props: { className: 'blue' }}

一个React元素没有宿主实例与它绑定,他只是描述你想在屏幕上看到的UI的描述,所以他是轻量级的。

就如同宿主实例,React也能实现树结构:

// 用JSX语法糖对这些对象描述// 
//
//
//
{ type: 'dialog', props: { children: [{ type: 'button', props: { className: 'blue' } }, { type: 'button', props: { className: 'red' } }] }}

(提示:我忽视了一些对解释这个概念并不重要的属性)

但是,请记住React元素没有一致性的标记。他们总是不断的重建和销毁。

React元素是不可变的。比如,你不能改变一个React元素的children属性和其他属性。如果你想渲染与之前不同的内容,你要重头开始描述一个新的React元素。
我喜欢把React元素比做电影中的每一帧。它们描述了UI在某一刻的状态,它们永远不会改变。

2. 入口

每一个React渲染器都有一个入口。就是那个告诉React把特定的React元素树渲染到宿主实例中的API。

ReactDOM.render(  // { type: 'button', props: { className: 'blue' } }  ,  document.getElementById('container'));

当我们说ReactDOM.render(reactElement, domContainer),就意味着:“亲爱的React,将我的React元素放到domContainer 的宿主树去”。

React会看着reactElement.type(在我们的例子中,‘button’)并告诉React Dom renderer 创造一个宿主实例并且设置属性:

function createHostInstance(reactElement) {  let domNode = document.createElement(reactElement.type);  domNode.className = reactElement.props.className;  return domNode;}

在我们的例子中,代码如下

let domNode = document.createElement('button');domNode.className = 'blue';domContainer.appendChild(domNode);

如果 React 元素在 reactElement.props.children 中含有子元素,React 会在第一次渲染中递归地为它们创建宿主实例。

转载地址:http://wfqyo.baihongyu.com/

你可能感兴趣的文章
高通64位ARMv8系列服务器芯片商标命名:Centriq
查看>>
中国人工智能学会通讯——融合经济学原理的个性化推荐 1.1 互联网经济系统的基本问题...
查看>>
盘点大数据商业智能的十大戒律
查看>>
戴尔为保护数据安全 推出新款服务器PowerEdge T30
查看>>
今年以来硅晶圆涨幅约达40%
查看>>
构建智能的新一代网络——专访Mellanox市场部副总裁 Gilad Shainer
查看>>
《数字视频和高清:算法和接口》一导读
查看>>
《中国人工智能学会通讯》——6.6 实体消歧技术研究
查看>>
如何在Windows查看端口占用情况及查杀进程
查看>>
云存储应用Upthere获7700万美元股权债务融资
查看>>
国家互联网应急中心何世平博士主题演讲
查看>>
洗茶,你误会了多少年?
查看>>
移动大数据“后市场”受青睐 亟需数据深度学习人才
查看>>
贵阳高新区力争打造“千亿级大数据园区”
查看>>
安防众筹不止于卖产品 思维拓展刺激消费
查看>>
OpenSSH曝高危漏洞 会泄露私钥
查看>>
艾特网能获2016APCA用户满意品牌大奖
查看>>
《软件工艺师:专业、务实、自豪》一2.4 《敏捷软件开发宣言》
查看>>
《CCNP TSHOOT 300-135学习指南》——第2章 结构化故障检测与排除进程
查看>>
《Java EE 7精粹》—— 2.5 非阻塞I/O
查看>>