摘要:元素在宿主環境中,一個宿主實例是最小的單位像節點。在中最小的單位是元素。他們總是不斷的重建和銷毀。元素是不可變的。比如,你不能改變一個元素的屬性和其他屬性。入口每一個渲染器都有一個入口。當我們說,就意味著親愛的,將我的元素放到的宿主樹去。
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在某一刻的狀態,它們永遠不會改變。
每一個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://m.specialneedsforspecialkids.com/yun/101788.html
摘要:我們不想要因為重新創建元素而失去它的選中狀態,聚焦狀態和顯示內容。幸好這個問題有一個簡單的修復方式,他并不在應用中常見。那么會執行類似于下面的代碼的狀態并不會改變 如果React在更新中只重用與元素類型相匹配的宿主實例,那按渲染條件選擇的內容怎么辦呢?正如下面的代碼,假如我們開始至需要一個input,但稍后需要在它之前渲染一個message : // 第一次渲染 ReactDOM.re...
摘要:但是這只在子元素的位置是靜止的并且不需要重排。這可能會引起性能問題和可能的。當在中發現,它就會檢查之前版本中的是否同樣含有。并沒有慣用的支持對在不重新創建元素的情況下讓宿主實例在不同的父元素之間移動。 通過比較樹中的元素是否在同一位置,通常已經足夠判斷是否是重用還是再次創建通信組件了。但是這只在子元素的位置是靜止的并且不需要重排。在我們的上述的例子中,即使message不存在,我們仍然...
摘要:確定宿主樹怎么樣來響應新的信息的這個過程被稱為協調。協調有兩種方法。我們已經創建了一個作為第一個也是唯一一個子元素,并且我們希望在同一個地方再次渲染一個。這個已經與的思想非常接近了。 1.協調 如果我們在同一個容器中使用兩次ReactDOM.render()會發生什么? ReactDOM.render( , document.getElementById(container) ...
摘要:屬性我們還可以使用來書寫樣式,它會自動幫我們編譯為格式內容語法高亮建議使用配合該擴展支持語法高亮擴展開發項目,當然你可以把文件當作對待。 Omil 是什么? Omil是一個 webpack 的 loader,它允許你以一種名為單文件組件(SFCs)的格式撰寫 Omi 組件: ${this.data.title} export default class { test(){...
閱讀 3209·2021-11-10 11:36
閱讀 3155·2021-11-02 14:39
閱讀 1737·2021-09-26 10:11
閱讀 4975·2021-09-22 15:57
閱讀 1697·2021-09-09 11:36
閱讀 2057·2019-08-30 12:56
閱讀 3497·2019-08-30 11:17
閱讀 1707·2019-08-29 17:17