《React 思維進化》新書分享會

 

Zet Chou@ALPHA Camp

2024.01.20

  • iCHEF Lead Front-End Engineer

  • 近十年前端開發經驗,九年 React 開發經驗

  • 曾任 SITCON、JSDC 主議程講者

  • JSDC 2019 / 2020 議程組工作人員

  • ALPHA Camp web dev 助教 

  • 第 14 屆 IThome 鐵人賽 Modern Web 組冠軍

    • 《一次打破 React 常見的學習門檻與觀念誤解》

  • 《React 思維進化:一次打破常見的觀念誤解,躍升專業前端開發者》筆者

Zet

周昱安

About me

寫這本書的動機

為什麼 React 這麼難學的好

  • React 有大量機制依賴了 JavaScript 的核心特性
    • 所以 JS 基礎不穩的人在學習 React 時通常會非常辛苦
  • React 的學習會比其他前端技術更依賴於設計模式等「心智模型的認知」
    • React 的學習不適合「從實踐中出真知」,這些核心觀念並不會因為寫的 React 專案越多就突然自己憑空開竅
  • React 的設計精神導致它很難確保開發者的下限,而是盡量拉高上限與減少黑魔法
    • 在確保下限以及降低學習門檻的面向,Vue 就比 React 做得好很多

常見的 React 學習瓶頸

  • 只會呼叫語法,卻對 React 運作的原理與觀念一知半解

    • JSX、Reconciliation、immutable update、useEffect...

  • 觀念與觀念之間的關聯破碎,無法融會貫通變成一個知識體系

  • 以上的問題導致實作了很多專案但技術理解卻沒有什麼進展,很常憑感覺以及模糊的經驗在寫程式,為專案的程式碼品質和可靠性埋下隱患

source: 9GAG

目前已有的學習資源的問題

  • 現有的 React 學習資源品質參差不齊,甚至錯誤資訊比正確資訊還多,學習者容易接觸到不準確的觀念
  • 觀念正確且優秀的 React 技術文章稀有,尤其是台灣正體中文的相關資源更少,而且這些文章通常偏向單點、碎片化知識時,缺乏足夠前提理解的學習者難以形成完整的知識框架與體系
  • 因此,我才會想要透過參加鐵人賽以及出書來建立一個「連續性、系統性」的 React 核心觀念學習資源,將重點擺在技術背後的運作流程與觀念、設計思維與脈絡

常見的觀念誤解

  • 在 React 中一切都是 component,component 是構成畫面的最小單位
  • JSX 語法是在 JavaScript 當中寫 HTML
  • useEffect 是 function component 的生命週期 API,可以用來模擬 class component 的 componentDidMountcomponentWillUnmount

常見的觀念誤解

  • 在 React 中一切都是 component,component 是構成畫面的最小單位
  • JSX 語法是在 JavaScript 當中寫 HTML
  • useEffect 是 function component 的生命週期 API,可以用來模擬 class component 的 componentDidMountcomponentWillUnmount

更好的 React 學習脈絡

學習一門程式技術的四大面向

核心觀念與原理

基礎語法、工具、API 的使用方法 & 基礎操作練習

專案實戰情境經驗累積

抽象化設計 & patterns

學習核心知識,了解程式運作的核心概念與原理。這是後續所有學習階段的重要根基,沒有先把觀念基本功打穩的話,後續的學習則大多都是在做白工,難以突破

學習實務操作的基本方法並動手練習,並且連結回核心觀念與知識,達到理論與實作的融會貫通

在實戰情境需求中實踐技術的應用,並從其中累積面對不同情境時需要額外注意並處理的面向的經驗

學習如何在正確滿足商業規格需求的同時,進一步讓程式碼設計得更有擴充彈性、可讀性,並易於測試

掌握基本技術能力

有一定的即戰力

通往 senior level 必須的能力之一

學習 React 應該從哪裡開始

  • 絕大多數學習資源都會從 JSX 或 component 直接開始講起,而這會造成學習脈絡的斷層:
    • JSX 語法的本質到底是什麼?為什麼可以在 JavaScript 裡面寫像是 HTML 的東西?
    • 為什麼需要 component?它跟 React 畫面的管理機制有什麼關聯?
    • 這些東西與過去未接觸前端框架時手動操作 DOM 的開發模式有什麼關聯?

學習 React 應該從哪裡開始

  • 應該從完全沒有接觸過 React 或任何前端框架的程度開始銜接,並以循序漸進的脈絡慢慢延伸
    • 有一定的 JavaScript 掌握程度
    • 了解怎麼透過操作 DOM 來更新瀏覽器畫面
  • 必須先從零一步一步解析 React 的「畫面管理機制」
    • 過去未使用前端框架或解決方案時,處理 UI 畫面管理的痛點
    • 了解 React 透過怎樣的策略以及實踐,來代替開發者操作 DOM 並管理畫面

關於《React 思維進化》

全彩的視覺閱讀體驗+軟精裝限量

  • 注重觀念理解
    • 深入剖析 React 核心觀念與運作原理
  • 脈絡循序漸進
    • 從零堆疊技術脈絡,新手老手都適用
  • 額外技術知識點專欄
    • 補充文中提及的各種技術知識點
  • 筆者思維分享
    • 分享筆者對於 React 學習脈絡的個人見解

 

本書特色

目錄與章節開箱導讀

Q & A 交流

活動報名時的問題收集

天瓏書局購書傳送門

特別感謝 五倍學院 協助本活動宣傳

Thanks!

React2

By tz5514

React2

  • 166