成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

React.js 小書 Lesson1-2 - 前端組件化(一):從一個簡單的例子講起

null1145 / 2249人閱讀

摘要:一個組件的顯示形態(tài)和行為有可能是由某些數(shù)據(jù)決定的。一個簡單的點贊功能我們會從一個簡單的點贊功能講起。我們需要結(jié)構(gòu),準確地來說我們需要這個點贊功能的字符串表示的結(jié)構(gòu)。下一節(jié)小書前端組件化二優(yōu)化操作中我們繼續(xù)優(yōu)化這個例子,讓它更加通用。

React.js 小書 Lesson1-2 - 前端組件化(一):從一個簡單的例子講起

本文作者:胡子大哈
本文原文:http://huziketang.com/books/react/lesson2

轉(zhuǎn)載請注明出處,保留原文鏈接以及作者信息

在線閱讀:http://huziketang.com/books/react/

React.js 是一個幫助你構(gòu)建頁面 UI 的庫。如果你熟悉 MVC 概念的話,那么 React 的組件就相當于 MVC 里面的 View。如果你不熟悉也沒關系,你可以簡單地理解為,React.js 將幫助我們將界面分成了各個獨立的小塊,每一個塊就是組件,這些組件之間可以組合、嵌套,就成了我們的頁面。

一個組件的顯示形態(tài)和行為有可能是由某些數(shù)據(jù)決定的。而數(shù)據(jù)是可能發(fā)生改變的,這時候組件的顯示形態(tài)就會發(fā)生相應的改變。而 React.js 也提供了一種非常高效的方式幫助我們做到了數(shù)據(jù)和組件顯示形態(tài)之間的同步。

React.js 不是一個框架,它只是一個庫。它只提供 UI (view)層面的解決方案。在實際的項目當中,它并不能解決我們所有的問題,需要結(jié)合其它的庫,例如 Redux、React-router 等來協(xié)助提供完整的解決方法。

很多課程一上來就給大家如何配置環(huán)境、怎么寫 React.js 組件。但是本課程還是希望大家對問題的根源有一個更加深入的了解,其實很多的庫、框架都是解決類似的問題。只有我們對這些庫、框架解決的問題有深入的了解和思考以后,我們才能得心應手地使用它們,并且有新的框架出來也不會太過迷茫;因為其實它們解決都是同一個問題。

這兩節(jié)課我們來探討一下是什么樣的問題導致了我們需要前端頁面進行組件化,前端頁面的組件化需要解決什么樣的問題。后續(xù)課程我們再來看看 React.js 是怎么解決這些問題的。

所以這幾節(jié)所講的內(nèi)容將和 React.js 的內(nèi)容沒有太大的關系,但是如果你能順利了解這幾節(jié)的內(nèi)容,那么后面哪些對新手來說很復雜的概念對你來說就是非常自然的事。

一個簡單的點贊功能

我們會從一個簡單的點贊功能講起。 假設現(xiàn)在我們需要實現(xiàn)一個點贊、取消點贊的功能。

如果你對前端稍微有一點了解,你就順手拈來:

HTML:

  
    

為了模擬現(xiàn)實當中的實際情況,所以這里特意把這個 button 里面的 HTML 結(jié)構(gòu)搞得稍微復雜一些。有了這個 HTML 結(jié)構(gòu),現(xiàn)在就給它加入一些 JavaScript 的行為:

JavaScript:

  const button = document.querySelector(".like-btn")
  const buttonText = button.querySelector(".like-text")
  let isLiked = false
  button.addEventListener("click", () => {
    isLiked = !isLiked
    if (isLiked) {
      buttonText.innerHTML = "取消"
    } else {
      buttonText.innerHTML = "點贊"
    }
  }, false)

功能和實現(xiàn)都很簡單,按鈕已經(jīng)可以提供點贊和取消點贊的功能。這時候你的同事跑過來了,說他很喜歡你的按鈕,他也想用你寫的這個點贊功能。這時候問題就來了,你就會發(fā)現(xiàn)這種實現(xiàn)方式很致命:你的同事要把整個 button 和里面的結(jié)構(gòu)復制過去,還有整段 JavaScript 代碼也要復制過去。這樣的實現(xiàn)方式?jīng)]有任何可復用性。

結(jié)構(gòu)復用

現(xiàn)在我們來重新編寫這個點贊功能,讓它具備一定的可復用。這次我們先寫一個類,這個類有 render 方法,這個方法里面直接返回一個表示 HTML 結(jié)構(gòu)的字符串:

  class LikeButton {
    render () {
      return `
        
      `
    }
  }

然后可以用這個類來構(gòu)建不同的點贊功能的實例,然后把它們插到頁面中。

  const wrapper = document.querySelector(".wrapper")
  const likeButton1 = new LikeButton()
  wrapper.innerHTML = likeButton1.render()
  
  const likeButton2 = new LikeButton()
  wrapper.innerHTML += likeButton2.render()

這里非常暴力地使用了 innerHTML ,把兩個按鈕粗魯?shù)夭迦肓?wrapper 當中。雖然你可能會對這種實現(xiàn)方式非常不滿意,但我們還是勉強了實現(xiàn)了結(jié)構(gòu)的復用。我們后面再來優(yōu)化它。

實現(xiàn)簡單的組件化

你一定會發(fā)現(xiàn),現(xiàn)在的按鈕是死的,你點擊它它根本不會有什么反應。因為根本沒有往上面添加事件。但是問題來了,LikeButton 類里面是雖然說有一個 button,但是這玩意根本就是在字符串里面的。你怎么能往一個字符串里面添加事件呢?DOM 事件的 API 只有 DOM 結(jié)構(gòu)才能用。

我們需要 DOM 結(jié)構(gòu),準確地來說:我們需要這個點贊功能的 HTML 字符串表示的 DOM 結(jié)構(gòu)。假設我們現(xiàn)在有一個函數(shù) createDOMFromString ,你往這個函數(shù)傳入 HTML 字符串,但是它會把相應的 DOM 元素返回給你。這個問題就可以額解決了。

// ::String => ::Document
const createDOMFromString = (domString) => {
  // TODO 
}

先不用管這個函數(shù)應該怎么實現(xiàn),先知道它是干嘛的。拿來用就好,這時候用它來改寫一下 LikeButton 類:

  class LikeButton {
    render () {
      this.el = createDOMFromString(`
        
      `)
      this.el.addEventListener("click", () => console.log("click"), false)
      return this.el
    }
  }

現(xiàn)在 render() 返回的不是一個 html 字符串了,而是一個由這個 html 字符串所生成的 DOM。在返回 DOM 元素之前會先給這個 DOM 元素上添加事件再返回。

因為現(xiàn)在 render 返回的是 DOM 元素,所以不能用 innerHTML 暴力地插入 wrapper。而是要用 DOM API 插進去。

  const wrapper = document.querySelector(".wrapper")

  const likeButton1 = new LikeButton()
  wrapper.appendChild(likeButton1.render())

  const likeButton2 = new LikeButton()
  wrapper.appendChild(likeButton2.render())

現(xiàn)在你點擊這兩個按鈕,每個按鈕都會在控制臺打印 click,說明事件綁定成功了。但是按鈕上的文本還是沒有發(fā)生改變,只要稍微改動一下 LikeButton 的代碼就可以完成完整的功能:

  class LikeButton {
    constructor () {
      this.state = { isLiked: false }
    }

    changeLikeText () {
      const likeText = this.el.querySelector(".like-text")
      this.state.isLiked = !this.state.isLiked
      likeText.innerHTML = this.state.isLiked ? "取消" : "點贊"
    }

    render () {
      this.el = createDOMFromString(`
        
      `)
      this.el.addEventListener("click", this.changeLikeText.bind(this), false)
      return this.el
    }
  }

這里的代碼稍微長了一些,但是還是很好理解。只不過是在給 LikeButton 類添加了構(gòu)造函數(shù),這個構(gòu)造函數(shù)會給每一個 LikeButton 的實例添加一個對象 state,state 里面保存了每個按鈕自己是否點贊的狀態(tài)。還改寫了原來的事件綁定函數(shù):原來只打印 click,現(xiàn)在點擊的按鈕的時候會調(diào)用 changeLikeText 方法,這個方法會根據(jù) this.state 的狀態(tài)改變點贊按鈕的文本。

現(xiàn)在這個組件的可復用性已經(jīng)很不錯了,你的同事們只要實例化一下然后插入到 DOM 里面去就好了。

下一節(jié)《React.js 小書 Lesson3 - 前端組件化(二):優(yōu)化 DOM 操作》中我們繼續(xù)優(yōu)化這個例子,讓它更加通用。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/89655.html

相關文章

  • 本關于 React.js 小書

    摘要:因為工作中一直在使用,也一直以來想總結(jié)一下自己關于的一些知識經(jīng)驗。于是把一些想法慢慢整理書寫下來,做成一本開源免費專業(yè)簡單的入門級別的小書,提供給社區(qū)。本書的后續(xù)可能會做成視頻版本,敬請期待。本作品采用署名禁止演繹國際許可協(xié)議進行許可 React.js 小書 本文作者:胡子大哈本文原文:React.js 小書 轉(zhuǎn)載請注明出處,保留原文鏈接以及作者信息 在線閱讀:http://huzi...

    Scorpion 評論0 收藏0
  • React.js 小書 Lesson3 - 前端件化(二):優(yōu)化 DOM 操作

    摘要:一個組件的顯示形態(tài)由多個狀態(tài)決定的情況非常常見。我們順利地消除了手動的操作。非一般的暴力,因為每次都重新構(gòu)造新增刪除元素,會導致瀏覽器進行大量的重排,嚴重影響性能。下一節(jié)小書前端組件化三抽象出公共組件類我們把這個通用模式抽離到一個類當中。 React.js 小書 Lesson3 - 前端組件化(二):優(yōu)化 DOM 操作 本文作者:胡子大哈本文原文:http://huziketang....

    Drinkey 評論0 收藏0
  • 2017-09-07 前端日報

    摘要:前端日報精選機制詳解與中實踐應用基礎與實踐如何用獲取虛擬鍵盤高度適用所有平臺和入門教程阮一峰的網(wǎng)絡日志編程技能提升指南中文到底什么是又是什么眾成翻譯調(diào)用模塊騰訊前端團隊社區(qū)小書從一個簡單的例子講起小書教程小書優(yōu)化操作小書教 2017-09-07 前端日報 精選 JavaScript Event Loop 機制詳解與 Vue.js 中實踐應用 Redux 基礎與實踐如何用 js 獲取虛擬...

    沈儉 評論0 收藏0
  • React.js 小書 Lesson17 - 前端應用狀態(tài)管理 —— 狀態(tài)提升

    摘要:在實際項目當中狀態(tài)提升并不是一個好的解決方案,所以我們后續(xù)會引入這樣的狀態(tài)管理工具來幫助我們來管理這種共享狀態(tài),但是在講解到之前,我們暫時采取狀態(tài)提升的方式來進行管理。 React.js 小書 Lesson17 - 前端應用狀態(tài)管理 —— 狀態(tài)提升 本文作者:胡子大哈本文原文:http://huziketang.com/books/react/lesson17 轉(zhuǎn)載請注明出處,保留原...

    newtrek 評論0 收藏0
  • React.js 小書 Lesson4 - 前端件化(三):抽象出公共組件

    摘要:最后抽離出來了一個類,可以幫助我們更好的做組件化。一個組件有自己的顯示形態(tài)上面的結(jié)構(gòu)和內(nèi)容行為,組件的顯示形態(tài)和行為可以由數(shù)據(jù)狀態(tài)和配置參數(shù)共同決定。接下來我們開始正式進入主題,開始正式介紹。下一節(jié)鏈接直達小書基本環(huán)境安裝 React.js 小書 Lesson4 - 前端組件化(三):抽象出公共組件類 本文作者:胡子大哈本文原文:http://huziketang.com/books...

    jsbintask 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<