日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

函數組件和函數式編程有關系么?

來源: 責編: 時間:2023-11-21 09:38:59 303觀看
導讀大家好,我卡頌。長期使用React的同學應該知道,React中存在兩種組件:Class Component,類組件Function Component,函數組件既然提到「類」和「函數」,那么很自然的,我們會進一步思考:類組件和OOP(面向對象編程)有關系么?函數組件和

35P28資訊網——每日最新資訊28at.com

大家好,我卡頌。35P28資訊網——每日最新資訊28at.com

長期使用React的同學應該知道,React中存在兩種組件:35P28資訊網——每日最新資訊28at.com

  • Class Component,類組件
  • Function Component,函數組件

既然提到「類」和「函數」,那么很自然的,我們會進一步思考:35P28資訊網——每日最新資訊28at.com

  • 類組件和OOP(面向對象編程)有關系么?
  • 函數組件和FP(函數式編程)有關系么?

畢竟,如果類組件和OOP有關,那么OOP中的思想(繼承、封裝、多態...)也能指導類組件的業務開發(函數組件與FP的關系同理)。換言之,我們可以直接用這些編程范式的最佳實踐指導React項目開發。35P28資訊網——每日最新資訊28at.com

那么,「函數組件」和「函數式編程」究竟是什么關系呢?本文會圍繞這個話題展開講解。35P28資訊網——每日最新資訊28at.com

編程范式與DSL

首先,我們應該明確,「框架語法」本質是一種DSL(領域相關語言),他是為了「某個特定領域的開發」量身定制的。35P28資訊網——每日最新資訊28at.com

比如,React作為一款針對「view開發」的DSL,雖然不同的view使用的框架不同,比如:35P28資訊網——每日最新資訊28at.com

  • 對于web,框架為ReactDOM。
  • 對于小程序,框架為Taro。
  • 對于原生開發,字節內部有個叫React Lynx的框架。

但這些框架都大體遵循同一套DSL(React語法),這套DSL并不屬于某一種編程范式,而應該被視為「不同編程范式中,更符合view開發的語言特性的集合」。35P28資訊網——每日最新資訊28at.com

所以,作為React DSL的一部分,函數組件可以體現OOP的思想,類組件也能體現FP的思想。只要這些思想有利于「view開發」,就可以納入DSL的語法中。35P28資訊網——每日最新資訊28at.com

比如,下面的函數組件Header,是由WelcomeMessage與LogoutButton組件組合而成,這是OOP中的「組合優于繼承」思想:35P28資訊網——每日最新資訊28at.com

function Header(props) {  return (    <div>      <WelcomeMessage name={props.name} />      <LogoutButton onClick={props.onLogout} />    </div>  );}

再比如,下面的類組件Cpn中,要改變狀態count,并不是通過突變(類似this.state.count++),而是調用this.setState,傳入不可變數據:35P28資訊網——每日最新資訊28at.com

class Cpn extends React.Component {  // ...  onClick() {    const count = this.state.count;    this.setState({count: count + 1});  }  render() {    // ...  }}

「使用不可變數據」屬于FP中的思想。35P28資訊網——每日最新資訊28at.com

所以,當我們要深入了解某個React特性時,應該以如下順序遞進的思考:35P28資訊網——每日最新資訊28at.com

  • React的開發理念是什么?
  • 為了實現這套理念,吸收了哪些編程范式中的思想。
  • 這些思想如何在React中落地。

如果我們用上述思考過程研究「函數組件與函數式編程的關系」,會發現:35P28資訊網——每日最新資訊28at.com

  • 函數組件屬于落地的產物(上述思考的第三步)。
  • 函數式編程屬于編程范式(上述思考的第二步)。

這就是兩者的關系 —— 函數組件屬于多種編程范式(主要是OOP與FP)在React中最終的落地產物,其中借鑒了一部分FP的思想。35P28資訊網——每日最新資訊28at.com

我們不應該將函數組件單純視為FP在React中的具象體現。35P28資訊網——每日最新資訊28at.com

那么,函數組件究竟是如何演進而來的呢?35P28資訊網——每日最新資訊28at.com

函數組件的演進

讓我們按照上述三步演進順序思考。首先,React的開發理念踐行了如下公式(即:UI是數據快照經過函數映射而來):35P28資訊網——每日最新資訊28at.com

UI = fn(snapshot)

要落地這個理念,有兩個要素需要實現:35P28資訊網——每日最新資訊28at.com

  • 數據快照
  • 函數映射

在這里,FP中「不可變數據」更適合作為「數據快照」的載體,所以React中狀態是不可變的,因為狀態的本質是快照。35P28資訊網——每日最新資訊28at.com

而「函數映射」的載體則沒有特殊要求。在React中,每次觸發更新,所有組件都會重新render,render的過程就是「函數映射」的過程,輸入是props與state,輸出是JSX。35P28資訊網——每日最新資訊28at.com

與React相對的,Vue中組件則更符合OOP的理念,考慮如下App組件:35P28資訊網——每日最新資訊28at.com

const App = {  setup(initialProps) {    const count = reactive({count: 0})    const add = () => { count.value++ }    return {count, add}  }  template: "...省略"}

組件的setup方法只會在初始化時執行一次,后續觸發更新時操作的都是同一個閉包中的數據。這里面的閉包就是OOP思想中的實例。35P28資訊網——每日最新資訊28at.com

既然React對「函數映射」的載體沒有特殊要求,那么類組件、函數組件都是可以的。35P28資訊網——每日最新資訊28at.com

那為什么函數組件最終替代了類組件成為React開發的主流呢?很多同學認為「函數組件的Hooks可以更好的復用邏輯」這一點,是函數組件優于類組件的主要原因。35P28資訊網——每日最新資訊28at.com

但實際上,基于裝飾器的類開發模式早已被驗證是優秀的邏輯復用模式,類組件配合TS裝飾器的模式是行得通的。35P28資訊網——每日最新資訊28at.com

主要原因還是 —— 函數組件能夠更好的落地UI = fn(snapshot)這一理念。35P28資訊網——每日最新資訊28at.com

剛才說過,公式中的snapshot是「快照」的含義。在React中,快照主要包括三類數據:35P28資訊網——每日最新資訊28at.com

  • state
  • props
  • context

對于同一個組件,根據公式UI = fn(snapshot),相同的快照輸入應該獲得相同輸出(JSX)。35P28資訊網——每日最新資訊28at.com

但狀態更新也可能觸發「副作用」,比如請求數據、操作DOM...35P28資訊網——每日最新資訊28at.com

在類組件中,這些「副作用」邏輯被分散在各個生命周期鉤子函數中,React無法掌控。35P28資訊網——每日最新資訊28at.com

而在函數組件中:35P28資訊網——每日最新資訊28at.com

  • 副作用受限在useEffect中。每次render,React都會保證上次的副作用效果已經被清除(通過useEffect回調的返回值函數)
  • ref的傳播也需要借由forwardRef,這進一步限制了ref可能的影響范圍。
  • 數據請求的副作用被交給Suspense處理,考慮下面組件:
function UserList({id}) {  // 異步請求數據  const data = use(fetchUser(id));    // ...}

使用時:35P28資訊網——每日最新資訊28at.com

<Suspense fallback={<div>加載中...</div>}>  <UserList id={1}/></Suspense>

總而言之,使用函數組件時,所有副作用都處于一種「受到管控」的狀態,可以盡可能保證每次更新時「相同的快照輸入,獲得相同的JSX輸出」,所以函數組件在React中才會發揚光大。35P28資訊網——每日最新資訊28at.com

同時,這也契合了FP中的純函數思想。35P28資訊網——每日最新資訊28at.com

總結

「函數組件」并不是「函數式編程」在React中的具體實現,而是React的設計理念UI = fn(snapshot)落地的最好載體。35P28資訊網——每日最新資訊28at.com

在React中,還吸收了其他編程范式中的優秀思想。FP只是其中影響React最深的一種。畢竟,一切落地都是為了踐行最初的設計理念。35P28資訊網——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-32010-0.html函數組件和函數式編程有關系么?

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: Go 內存分配:結構體中的優化技巧

下一篇: 揭秘系列:Goroutine調度器

標簽:
  • 熱門焦點
  • 7月安卓手機性能榜:紅魔8S Pro再奪榜首

    7月份的手機市場風平浪靜,除了紅魔和努比亞帶來了兩款搭載驍龍8Gen2領先版處理器的新機之外,別的也想不到有什么新品了,這也正常,通常6月7月都是手機廠商修整的時間,進入8月份之
  • CSS單標簽實現轉轉logo

    轉轉品牌升級后更新了全新的Logo,今天我們用純CSS來實現轉轉的新Logo,為了有一定的挑戰性,這里我們只使用一個標簽實現,將最大化的使用CSS能力完成Logo的繪制與動畫效果。新logo
  • 之家push系統迭代之路

    前言在這個信息爆炸的互聯網時代,能夠及時準確獲取信息是當今社會要解決的關鍵問題之一。隨著之家用戶體量和內容規模的不斷增大,傳統的靠"主動拉"獲取信息的方式已不能滿足用
  • 花7萬退貨退款無門:誰在縱容淘寶珠寶商家造假?

    來源:極點商業作者:楊銘在淘寶購買珠寶玉石后,因為保證金不夠賠付,店鋪關閉,退貨退款難、維權無門的比比皆是。&ldquo;提供相關產品鑒定證書,支持全國復檢,可以30天無理由退換貨。&
  • 一條抖音4億人圍觀 ! 這家MCN比無憂傳媒還野

    作者:Hiu 來源:互聯網品牌官01 擦邊少女空降熱搜,幕后推手曝光被網友譽為&ldquo;純欲天花板&rdquo;的女網紅井川里予,近期因為一組哥特風照片登上熱搜,引發了一場互聯網世界關于
  • 認真聊聊東方甄選:如何告別低垂的果實

    來源:山核桃作者:財經無忌爆火一年后,俞敏洪和他的東方甄選依舊是頗受外界關心的&ldquo;網紅&rdquo;。7月5日至9日,為期5天的東方甄選&ldquo;甘肅行&rdquo;首次在自有App內直播,
  • iQOO 11S或7月上市:搭載“雞血版”驍龍8Gen2 史上最強5G Soc

    去年底,iQOO推出了“電競旗艦”iQOO 11系列,作為一款性能強機,iQOO 11不僅全球首發2K 144Hz E6全感屏,搭載了第二代驍龍8平臺及144Hz電競屏,同時在快充
  • 2299元起!iQOO Pad明晚首銷:性能最強天璣平板

    5月23日,iQOO如期舉行了新品發布會,除了首發安卓最強旗艦處理器的iQOO Neo8系列新機外,還在發布會上推出了旗下首款平板電腦——iQOO Pad,其最大的賣點
  • iQOO Neo8系列新品發布會

    旗艦雙芯 更強更Pro
Top 主站蜘蛛池模板: 梓潼县| 桂林市| 右玉县| 普宁市| 修水县| 舟山市| 焦作市| 张家界市| 隆回县| 博罗县| 东宁县| 丹巴县| 侯马市| 浦北县| 平凉市| 天长市| 昌都县| 娄烦县| 罗定市| 阳新县| 景宁| 清水河县| 苏尼特左旗| 青龙| 乐都县| 阿拉善左旗| 额济纳旗| 彩票| 观塘区| 江北区| 合水县| 庆城县| 濮阳县| 陕西省| 蓬溪县| 元氏县| 马公市| 黎城县| 新田县| 河曲县| 胶州市|