iT邦幫忙

2022 iThome 鐵人賽

DAY 1
1
自我挑戰組

菜雞也能優雅的征服RxJS系列 第 1

菜雞也能優雅的征服RxJS - day1-說說優雅的RxJS

  • 分享至 

  • xImage
  •  

  • 相信很多人學習Angualr一定對RxJS不陌生,但要輕易的駕馭它,可不是那麼容易。
  • 這年頭還有什麼我學不起來的!? 滿懷雄心壯志的開啟RxJS官網,不看則以,一看就被滿滿的文字海嘯給淹沒了,不死心地看了許多的影片想搞懂,不過,就像小琥姊的經典歌曲~沒有那麼簡單...?

一步一步探索RxJS

  • 一次偶然的機會,看到同事用RxJS將迴圈內的處理完畢,簡單俐落不說,還易讀易維護,這好東西不學~像話嗎??

  • 我懂RxJS的學習並不簡單,所以這一系列的文章,我會以淺顯易懂的方式來闡述我學習RxJS的歷程。✍

  • 一開始我們先從簡單的基礎觀念先熟悉,不貪多,每天進步一點就是一種成長;就跟少林寺學功夫一樣,先去挑水爬樓梯,蹲蹲馬步練穩下盤後,掌握降龍十八掌不再是難事。

  • 所以~跟著我一起一步一步探索RxJS!

想像一下,在一條生產線上...

  • 你開了一家香蕉包裝公司,建立一條完整的生產線中,你會有:
  • Source: 香蕉堆,陸續送出 ~ 第一串香蕉、第二串香蕉、第三串...第N串
  • Process: 製程,包含各種步驟,如:
  1. 觀察是否有腐爛?
  2. 秤重分類
  3. 清洗
  4. 包裝
    呈現的結果如下圖所示:

每個產品都經過層層把關

  • 注意到了嗎?生產線從一香蕉堆,陸續一串一串的把香蕉往生產線送。
  • 生產線總共設置了四個關卡,每一個關卡,都有自己的功能,各司其職,確認無誤,再往下一個(next)傳遞。
  • 當其中一串香蕉通過這四個關卡,也代表著我們能拿到包裝好的香蕉,準備出貨囉!
  • 這樣的層層把關,稱為pipe;也就是像管路依樣依序傳遞下去。

客戶下單訂閱,就可以開始生產囉!

  • Subscribe: 客戶要了解產線的生產狀況,當然會進行訂閱(Subscribe);訂閱了,就要開始生產囉!

來段RxJS程式碼模擬一下

import { filter, from, map } from 'rxjs';

console.log('=== RxJS模擬香蕉生產線 ===');
const bananaSrc = [1, 2, 3, 4, 5];

const bananaLine$ = from(bananaSrc).pipe(
  filter((num) => num % 2 !== 0), // 模擬奇數個是壞掉的
  map((banana) => `${banana}: Weight`), // 秤重
  map((banana) => `${banana} => Wash`), // 清洗
  map((banana) => `${banana} => Package`) // 包裝
);

bananaLine$.subscribe(console.log); // 訂閱,並印出生產資料
  • 輸出的結果如下
//=== RxJS模擬香蕉生產線 ===
// 1: Weight => Wash => Package
// 3: Weight => Wash => Package
// 5: Weight => Wash => Package

等等,這不就是Array Functional Programming嗎?

  • 沒錯RxJS就是結合Functional Programming,但這只是他的前菜而已,真正強大的功能在於簡化非同步(async)的處理程序。

Recap

  • RxJS的思維,就跟生產線一樣,其中進行著被觀察觀察的過程,想看的人可隨時可訂閱
  1. 被觀察(Observable): 一串一串的香蕉堆
  2. 觀察動作(observe): filterBad -> Weight => Wash => Package
  3. 訂閱(subscribe): 有人訂閱,代表生產正式啟動,你就可以拿到生產報告。
  • 恭喜你完成day1囉,你仍然有很多的疑問,沒關係,我們接下來的每一天,都一點一滴地說明這一切,加油。

下一篇
菜雞也能優雅的征服RxJS - day2- 被觀察者(Observable)與觀察者(Observer)的關係
系列文
菜雞也能優雅的征服RxJS32
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

2 則留言

0
黃升煌 Mike
iT邦研究生 5 級 ‧ 2022-09-06 17:42:41

看到 RxJS 的主題一定要大推!!期待完賽 /images/emoticon/emoticon08.gif

小偉哥 iT邦新手 4 級 ‧ 2022-09-06 17:51:38 檢舉

感謝Mike大的鼓勵,拜讀你的書及天梯網站,受益良多,有機會一定要請你簽名!

小偉哥 iT邦新手 4 級 ‧ 2022-09-06 17:52:25 檢舉

奇怪,icon變問號XD ==> 原來是emoji的問題

0
kika
iT邦新手 3 級 ‧ 2022-09-10 12:36:35

剛好在複習剛好在複習 Rxjs 來簽到XD

小偉哥 iT邦新手 4 級 ‧ 2022-09-11 08:01:54 檢舉

謝謝 kika, 一起學習,多多指教 ^^

我要留言

立即登入留言