※ 引述《ripple0129 (perry tsai)》之銘言:
: 看了一下
: React Native github八萬多顆星
: Flutter 短短兩年已經七萬三千了
: 衝的速度也太快
: 想必再過一年就超越了
: 現在是連寫原生的都來玩flutter是吧
: 寫Android的都在為fuchsia 做準備啦
我個人的看法是 你要先判斷一下你案子的需求到哪
再決定你要用什麼樣的方式開發
有時間有空閒的話 我覺得想要學什麼都可以學 只要自己有興趣
假如你提的這兩種你都會的話 根本不是什麼大問題
不管是Flutter也好 React也罷 都各有其優缺點
當然寫到資深的時候 容易有自己的個人偏好
例如就是喜歡某種語言某種框架 給你一種家的感覺
但成見不用太深 例如某種XX才會是王道
像我們公司有個資深工程師就是這樣
整天在那邊幹譙React 說用jQuery不好嗎
但就算把為何使用React 以及它跟傳統DOM的優缺點 還有組件化 做比較
他還是嫌得要死 因為他早就預設立場自己不想用這套了
順便附帶一提 他嫌的點大概有幾個
1.覺得React的code很髒 style/className/event handler都寫在component裡
沒辦法抽得很乾淨
2.我猜他看了文檔後 不想學Redux
第一點我覺得沒辦法 主要也是因為公司的案子規模都不算太大
而我們買的是付費的css template 公司又沒有專門的css行家
所以在不改動到底層css架構的前提下 有時候會偷懶寫在component裡
第二點的話我就沒辦法了 雖然Redux真的是很囉唆 要寫很多重複的boiler plate
但可以藉由Redux的design pattern去了解React傳參的痛點在哪其實也是滿好的
不過基本上Redux的時代已經過去了 現在我們新的案子已經完全使用hooks
而且管理global state的方式也找到更好的solution
對某種框架很執著 覺得別的都不行
通常是站在工程師的角度出發
但假如你用經營者的角度出發 可能想法會有所不同
再來也要取決於你案子的scope到哪
也要看這個案子預計他會存活多久 需不需要做大幅度或很頻繁的維護更新
例如我只是想做個簡單的工具app 雙平台 沒有太多酷炫的功能
鑲嵌個廣告賺個小收益 而我React很熟
那我就用RN開發就好 因為快速好維護
剩下就是解決一些跨平台與原生橋接溝通的坑
總之 有時間有興趣 你就都學
反正保持學習精神是碼農工作做得好不好的重要元素之一
想說我要學一套就獨霸武林 是有點不大實際的
揣摩預測未來走勢 學習新技能當然也是要的
不過這都是為將來下一份工作做打算先鋪路
當然也不用過於擔心 就算業界大老跳船
台灣目前開發使用的技術普遍都還是偏舊
想學flutter就慢慢摸仔細摸個兩三年
到時轉職可能就剛好timing對了
很多事情沒做之前都是多想的 有時間有興趣 就去研究就對了
就算你學了Flutter或RN之後在你的職業生涯中完全沒用上那也沒關係
因為你會在這個認真學習的過程中 吸收到這個語言或框架的優點
反思自己可以精進的地方
這樣也是進而幫助你 讓之後的code寫得更好
成長心態很重要 不能停止學習
做到這點 是碼農選工作 不是工作選碼農
台灣軟體開發產業雖然不如硬體 但這幾年需求漸漸也是起來了
之後應該也是會越來越多需求 因為這是時代趨勢 擋不住的
認真優質的碼農不缺工作 是你自己可以挑選喜歡的環境和做的東西
只要有能力 你可以寫任何你喜歡、你想寫的東西