摘要:最后抽離出來了一個類,可以幫助我們更好的做組件化。一個組件有自己的顯示形態(tài)上面的結(jié)構(gòu)和內(nèi)容行為,組件的顯示形態(tài)和行為可以由數(shù)據(jù)狀態(tài)和配置參數(shù)共同決定。接下來我們開始正式進入主題,開始正式介紹。下一節(jié)鏈接直達小書基本環(huán)境安裝
React.js 小書 Lesson4 - 前端組件化(三):抽象出公共組件類
本文作者:胡子大哈
本文原文:http://huziketang.com/books/react/lesson4
轉(zhuǎn)載請注明出處,保留原文鏈接以及作者信息
在線閱讀:http://huziketang.com/books/react
為了讓代碼更靈活,可以寫更多的組件,我們把這種模式抽象出來,放到一個 Component 類當(dāng)中:
class Component { setState (state) { const oldEl = this.el this.state = state this.el = this._renderDOM() if (this.onStateChange) this.onStateChange(oldEl, this.el) } _renderDOM () { this.el = createDOMFromString(this.render()) if (this.onClick) { this.el.addEventListener("click", this.onClick.bind(this), false) } return this.el } }
這個是一個組件父類 Component,所有的組件都可以繼承這個父類來構(gòu)建。它定義的兩個方法,一個是我們已經(jīng)很熟悉的 setState;一個是私有方法 _renderDOM。_renderDOM 方法會調(diào)用 this.render 來構(gòu)建 DOM 元素并且監(jiān)聽 onClick 事件。所以,組件子類繼承的時候只需要實現(xiàn)一個返回 HTML 字符串的 render 方法就可以了。
還有一個額外的 mount 的方法,其實就是把組件的 DOM 元素插入頁面,并且在 setState 的時候更新頁面:
const mount = (component, wrapper) => { wrapper.appendChild(component.renderDOM()) component.onStateChange = (oldEl, newEl) => { wrapper.insertBefore(newEl, oldEl) wrapper.removeChild(oldEl) } }
這樣的話我們重新寫點贊組件就會變成:
class LikeButton extends Component { constructor () { this.state = { isLiked: false } } onClick () { this.setState({ isLiked: !this.state.isLiked }) } render () { return ` ` } } mount(new LikeButton(), wrapper)
這樣還不夠好。在實際開發(fā)當(dāng)中,你可能需要給組件傳入一些自定義的配置數(shù)據(jù)。例如說想配置一下點贊按鈕的背景顏色,如果我給它傳入一個參數(shù),告訴它怎么設(shè)置自己的顏色。那么這個按鈕的定制性就更強了。所以我們可以給組件類和它的子類都傳入一個參數(shù) props,作為組件的配置參數(shù)。修改 Component 的構(gòu)造函數(shù)為:
... constructor (props = {}) { this.props = props } ...
繼承的時候通過 super(props) 把 props 傳給父類,這樣就可以通過 this.props 獲取到配置參數(shù):
class LikeButton extends Component { constructor (props) { super(props) this.state = { isLiked: false } } onClick () { this.setState({ isLiked: !this.state.isLiked }) } render () { return ` ` } } mount(new LikeButton({ bgColor: "red" }), wrapper)
這里我們稍微修改了一下原有的 LikeButton 的 render 方法,讓它可以根據(jù)傳入的參數(shù) this.props.bgColor 來生成不同的 style 屬性。這樣就可以自由配置組件的顏色了。
只要有了上面那個 Component 類和 mount 方法加起來不足40行代碼就可以做到組件化。如果我們需要寫另外一個組件,只需要像上面那樣,簡單地繼承一下 Component 類就好了:
class RedBlueButton extends Component { constructor (props) { super(props) this.state = { color: "red" } } onClick () { this.setState({ color: "blue" }) } render () { return `${this.state.color}` } }
簡單好用,現(xiàn)在可以靈活地組件化頁面了。
噢,忘了,還有一個神秘的 createDOMFromString,其實它更簡單:
const createDOMFromString = (domString) => { const div = document.createElement("div") div.innerHTML = domString return div }
Component 完整的代碼可以在這里找到 reactjs-in-40。
總結(jié)我們用了很長的篇幅來講一個簡單的點贊的例子,并且在這個過程里面一直在優(yōu)化編寫的方式。最后抽離出來了一個類,可以幫助我們更好的做組件化。在這個過程里面我們學(xué)到了什么?
組件化可以幫助我們解決前端結(jié)構(gòu)的復(fù)用性問題,整個頁面可以由這樣的不同的組件組合、嵌套構(gòu)成。
一個組件有自己的顯示形態(tài)(上面的 HTML 結(jié)構(gòu)和內(nèi)容)行為,組件的顯示形態(tài)和行為可以由數(shù)據(jù)狀態(tài)(state)和配置參數(shù)(props)共同決定。數(shù)據(jù)狀態(tài)和配置參數(shù)的改變都會影響到這個組件的顯示形態(tài)。
當(dāng)數(shù)據(jù)變化的時候,組件的顯示需要更新。所以如果組件化的模式能提供一種高效的方式自動化地幫助我們更新頁面,那也就可以大大地降低我們代碼的復(fù)雜度,帶來更好的可維護性。
好了,課程結(jié)束了。你已經(jīng)學(xué)會了怎么使用 React.js 了,因為我們已經(jīng)寫了一個——當(dāng)然我是在開玩笑,但是上面這個 Component 類其實和 React 的 Component 使用方式很類似。掌握了這幾節(jié)的課程,你基本就掌握了基礎(chǔ)的 React.js 的概念。
接下來我們開始正式進入主題,開始正式介紹 React.js。你會發(fā)現(xiàn),有了前面的鋪墊,下面講的內(nèi)容理解起來會簡單很多了。
下一節(jié)鏈接直達:《React.js 小書 - Lesson5 React.js 基本環(huán)境安裝》
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/89653.html
摘要:一個組件的顯示形態(tài)由多個狀態(tài)決定的情況非常常見。我們順利地消除了手動的操作。非一般的暴力,因為每次都重新構(gòu)造新增刪除元素,會導(dǎo)致瀏覽器進行大量的重排,嚴(yán)重影響性能。下一節(jié)小書前端組件化三抽象出公共組件類我們把這個通用模式抽離到一個類當(dāng)中。 React.js 小書 Lesson3 - 前端組件化(二):優(yōu)化 DOM 操作 本文作者:胡子大哈本文原文:http://huziketang....
摘要:因為工作中一直在使用,也一直以來想總結(jié)一下自己關(guān)于的一些知識經(jīng)驗。于是把一些想法慢慢整理書寫下來,做成一本開源免費專業(yè)簡單的入門級別的小書,提供給社區(qū)。本書的后續(xù)可能會做成視頻版本,敬請期待。本作品采用署名禁止演繹國際許可協(xié)議進行許可 React.js 小書 本文作者:胡子大哈本文原文:React.js 小書 轉(zhuǎn)載請注明出處,保留原文鏈接以及作者信息 在線閱讀:http://huzi...
摘要:在實際項目當(dāng)中狀態(tài)提升并不是一個好的解決方案,所以我們后續(xù)會引入這樣的狀態(tài)管理工具來幫助我們來管理這種共享狀態(tài),但是在講解到之前,我們暫時采取狀態(tài)提升的方式來進行管理。 React.js 小書 Lesson17 - 前端應(yīng)用狀態(tài)管理 —— 狀態(tài)提升 本文作者:胡子大哈本文原文:http://huziketang.com/books/react/lesson17 轉(zhuǎn)載請注明出處,保留原...
摘要:但是給傳遞的評論數(shù)據(jù)并沒有傳遞給,所以現(xiàn)在發(fā)表評論時沒有反應(yīng)的。包括實現(xiàn)功能之前先理解分析需求,劃分組件。到此為止,小書的第一階段已經(jīng)結(jié)束,你可以利用這些知識點來構(gòu)建簡單的功能模塊了。 React.js 小書 Lesson16 - 實戰(zhàn)分析:評論功能(三) 本文作者:胡子大哈本文原文:http://huziketang.com/books/react/lesson16 轉(zhuǎn)載請注明出處...
摘要:一個組件的顯示形態(tài)和行為有可能是由某些數(shù)據(jù)決定的。一個簡單的點贊功能我們會從一個簡單的點贊功能講起。我們需要結(jié)構(gòu),準(zhǔn)確地來說我們需要這個點贊功能的字符串表示的結(jié)構(gòu)。下一節(jié)小書前端組件化二優(yōu)化操作中我們繼續(xù)優(yōu)化這個例子,讓它更加通用。 React.js 小書 Lesson1-2 - 前端組件化(一):從一個簡單的例子講起 本文作者:胡子大哈本文原文:http://huziketang....
閱讀 3073·2021-11-11 16:55
閱讀 3215·2021-10-18 13:34
閱讀 604·2021-10-14 09:42
閱讀 1653·2021-09-03 10:30
閱讀 906·2021-08-05 10:02
閱讀 988·2019-08-30 11:27
閱讀 3495·2019-08-29 15:14
閱讀 1261·2019-08-29 13:02