内容简介:在宿主环境中,一个宿主实例是最小的单位(像DOM节点)。在React中最小的单位是React元素。一个React元素就是一个描述宿主实例的Javascript对象。一个React元素没有宿主实例与它绑定,他只是描述你想在屏幕上看到的UI的描述,所以他是轻量级的。
1、React元素
在宿主环境中,一个宿主实例是最小的单位(像DOM节点)。在React中最小的单位是React元素。
一个React元素就是一个描述宿主实例的Javascript对象。
// 用JSX语法糖对这个对象描述 // <button className="blue" /> { type: 'button', props: { className: 'blue' } }
一个React元素没有宿主实例与它绑定,他只是描述你想在屏幕上看到的UI的描述,所以他是轻量级的。
就如同宿主实例,React也能实现树结构:
// 用JSX语法糖对这些对象描述 // <dialog> // <button className="blue" /> // <button className="red" /> // </dialog> { 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' } } <button 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 会在第一次渲染中递归地为它们创建宿主实例。
以上所述就是小编给大家介绍的《React as a UI Runtime(二、React元素和入口)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
智能Web算法(第2版)
【英】Douglas G. McIlwraith(道格拉斯 G. 麦基尔雷思)、【美】Haralambos Marmanis(哈若拉玛 玛若曼尼斯)、【美】Dmitry Babenko(德米特里•巴邦科) / 达观数据、陈运文 等 / 电子工业出版社 / 2017-7 / 69.00
机器学习一直是人工智能研究领域的重要方向,而在大数据时代,来自Web 的数据采集、挖掘、应用技术又越来越受到瞩目,并创造着巨大的价值。本书是有关Web数据挖掘和机器学习技术的一本知名的著作,第2 版进一步加入了本领域最新的研究内容和应用案例,介绍了统计学、结构建模、推荐系统、数据分类、点击预测、深度学习、效果评估、数据采集等众多方面的内容。《智能Web算法(第2版)》内容翔实、案例生动,有很高的阅......一起来看看 《智能Web算法(第2版)》 这本书的介绍吧!
HTML 压缩/解压工具
在线压缩/解压 HTML 代码
JSON 在线解析
在线 JSON 格式化工具