今年(2021)之前,我是個(gè)忠實(shí)的react的用戶,用react做中臺(tái),后臺(tái),m站,pc站。做過ssr(nextjs),seo優(yōu)化等等。完全沒用過vue,或者其他的框架。
今年跟著人一起出來做東西,大佬說讓用vue做后臺(tái),我本來不大愿意,但是大佬張嘴了,那就搞吧。大概看了幾天,就直接用vue開始做業(yè)務(wù)功能了。
之后又看了一些vue源碼解析的文章(2.x版本)。從數(shù)據(jù)綁定,頁(yè)面渲染到watcher,批量更新,渲染優(yōu)化,事件系統(tǒng),與react對(duì)應(yīng)的功能做對(duì)比,發(fā)現(xiàn)經(jīng)驗(yàn)值漲了一大截。
當(dāng)時(shí)我第一次看到雙向綁定的時(shí)候,腦海中想到的場(chǎng)景是商品sku管理。
之前用react做過商品的sku管理,每次修改sku的某一個(gè)值,都要遍歷整個(gè)sku列表數(shù)據(jù),然后重新設(shè)置。但是在有雙向綁定的情況下,就不用每次重新生成一個(gè)sku數(shù)據(jù)源。
之后用vue重構(gòu)了一版sku,代碼量邏輯量都減了很多。
解決問題的框架才是好框架。嗯。。。
之后做m站,我看到了兩個(gè)很好的東西。
虛擬dom本來就是跨平臺(tái)基礎(chǔ),react hooks提供的函數(shù)式組件編程,跨平臺(tái)利器。跨平臺(tái)我感覺還是需要人力維護(hù)。
另一個(gè)我感覺很好用的--同構(gòu)。之前用nextjs做過(當(dāng)時(shí)比較菜,整天做頁(yè)面),首屏ssr渲染+之后csr渲染,解決了csr首屏加載問題與傳統(tǒng)ssr的體驗(yàn)問題。