左手Ionic冕房,右手年華

第一次親密接觸

第一次接觸Ionic,是在2015年趁矾,并在年中的時候第一次在正式項目中使用毒费,那時它才是Ionic1的Alpha版,每次版本更新仍有不少坑愈魏,但在可接受范圍觅玻,而且Ionic team一般會很快地修復Bug或者給出解決建議,就算他們沒有回復培漏,個人花點時間仍能找到折中處理方案溪厘。

其實,在使用Ionic前牌柄,移動端JS框架畸悬,我嘗試使用過Jquery Mobile(JM)、Sencha Touch(ST)珊佣,JM坑很多蹋宦,而ST相對好一些,但是性能有很大問題咒锻,如文件體積過大冷冗、內存占用過大等,而且UI實現(xiàn)對IDE不友好惑艇,或許后面都有所優(yōu)化了蒿辙,但是我沒等這一天。

因為有Angular1(Angularjs)的基礎滨巴,所以上手Ionic1很快思灌,它全家桶的功能,省卻了配套技術選型的煩惱恭取,同時泰偿,它比較齊全的cli命令,使得項目的創(chuàng)建到發(fā)布都比較簡便蜈垮。

那時的Ionic1還沒有懶加載耗跛。在我認為Ionic打包為App后,它的基礎文件在本地加載窃款,不依賴網絡開銷课兄,所以沒必要做懶加載處理時牍氛,架構師同伴卻執(zhí)著地進行懶加載改造晨继,沒有官方解決方案,我們啃國外的文檔搬俊,最后使用了ocLazyLoad處理(我們改造完幾個月后紊扬,才在國內看到一些相關文檔蜒茄,早期吃螃蟹的人都不容易)。后來的事實證明做懶加載還是有一定必要性的餐屎,在此基礎上檀葛,我們又陸續(xù)做了熱更新、動態(tài)渲染等功能腹缩,那時Ionic1的表現(xiàn)還不錯屿聋。

雖然Ionic1基本摸透了,但是它還是有一定學習成本藏鹊,為了團隊建設考量润讥,等Ionic2出來后,我們猶豫了一下是否沿用Ionic1盘寡,也比較了一下其它移動端js框架楚殿,最后還是敲定了升級使用Ionic2。然后v2竿痰、v3脆粥、v4一路走來,見證了Ionic的成熟影涉,也見證了其它混合式開發(fā)框架的誕生和崛起变隔。


新歡與舊愛

隨著Ionic4的推出,自己也較早時間去踩坑蟹倾,從去年中創(chuàng)建第一個Ionic4項目開始到現(xiàn)在弟胀,指導開發(fā)了幾個Ionic4項目,可以確切地說喊式,Ionic4已經穩(wěn)定了(僅限于Angular版孵户、Vue和React版的還有較長一段路要走),而且相對Ionic3來說岔留,組件更豐富夏哭、性能更優(yōu)化、機制更合理献联,同時兩者間差異不算變化很大竖配,可以很好的過渡(僅限于技術過渡,而不是舊項目過渡)里逆,對于新項目的選型进胯,可以考慮Ionic4替代Ionic3來開發(fā)。

Ionic4最大的感觀是在轉型原押,轉型向一個純粹的UI框架胁镐,借助Stencil,基于Web Components技術實現(xiàn)跨框架使用。其實如果Ionic3時盯漂,是采用Ionic4的技術線條颇玷,而Ionic4是下一個新的技術,那一定比現(xiàn)在更成功就缆。而現(xiàn)在帖渠,在其它競爭對手面前,Ionic4并不算有很亮眼的表現(xiàn)竭宰,一定程度上歸結于Angular的難度和在國內的受歡迎程度空郊。

其實,在我先前的文章中提到過Capacitor切揭,最開始它的官方文檔介紹有【Native UI View】這個內容渣淳,一度讓我以為Ionic版的RN要來了(與NativeScript不一樣的實現(xiàn)),后來發(fā)現(xiàn)相關內容被刪掉了伴箩,再后來看到相關團隊成員的文章里面提到過這個事情入愧,提到這是他們的一個夢想,只是這個工作量太大了嗤谚,所以把其它工作優(yōu)先處理棺蛛,這個先排除掉,但不知道什么時候再提上日程巩步。


亂花漸欲迷人眼

在我看來旁赊,Ionic4已經不再神秘,它和其它基于Angular的UI框架相比椅野,其實沒什么兩樣终畅,可以從很多Angular資料中找到參考,所以也便很少寫關于它的文章竟闪。一些從Ionic3過渡到Ionic4的人仍舊以Ionic3的思維去做開發(fā)离福,抱怨這個Ionic3可以,怎么到Ionic4不行炼蛤?Ionic3是Angular的基礎上封裝了一層妖爷,是Ionic3獨有使用,Ionic4把它開放還給了Angular理朋,就該用Angular的思維去做絮识。

就像我前面提到過的,Ionic有其它競爭對手嗽上,當你有較豐富的Angular經驗次舌,或者團隊的技術棧主要是Angular時,Ionic仍是不錯的選擇兽愤,它還有很長的生命周期彼念。當然針對不同的需求或項目規(guī)模挪圾,也可以選型其它技術,不用說綁死在一棵樹上国拇,或者悲觀地說我要放棄某種技術洛史。在我看來惯殊,很多時候酱吝,技術是殊途同歸的,懂了這個土思,了解其它也能很快上手务热,換了其它技術其實也代表你又學到了一樣東西,技術有了升華己儒。像我所在的公司崎岂,我可以決定選型的技術,就算我認為Angular比Vue更適合于中大型項目的開發(fā)管理闪湾,甚至我可以固執(zhí)地要求使用Angular冲甘,但考慮到招人的成本、框架的特點和國內的趨勢途样,一些項目我會考慮使用Vue江醇。

就算我在使用其它技術,我仍感謝Ionic的一路陪伴何暇,它曾經幫我實現(xiàn)了我想要的效果陶夜,它就像一瓶美酒靜靜躺在那里,哪天我想小酌一杯裆站,它仍會給我醇香……

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末条辟,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子宏胯,更是在濱河造成了極大的恐慌羽嫡,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件肩袍,死亡現(xiàn)場離奇詭異厂僧,居然都是意外死亡,警方通過查閱死者的電腦和手機了牛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進店門颜屠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人鹰祸,你說我怎么就攤上這事甫窟。” “怎么了蛙婴?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵粗井,是天一觀的道長。 經常有香客問我,道長浇衬,這世上最難降的妖魔是什么懒构? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮耘擂,結果婚禮上胆剧,老公的妹妹穿的比我還像新娘。我一直安慰自己醉冤,他們只是感情好秩霍,可當我...
    茶點故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蚁阳,像睡著了一般铃绒。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上螺捐,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天颠悬,我揣著相機與錄音,去河邊找鬼定血。 笑死赔癌,一個胖子當著我的面吹牛,可吹牛的內容都是我干的糠悼。 我是一名探鬼主播届榄,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼倔喂!你這毒婦竟也來了铝条?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤席噩,失蹤者是張志新(化名)和其女友劉穎班缰,沒想到半個月后,有當地人在樹林里發(fā)現(xiàn)了一具尸體悼枢,經...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡埠忘,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了馒索。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片莹妒。...
    茶點故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖绰上,靈堂內的尸體忽然破棺而出旨怠,到底是詐尸還是另有隱情,我是刑警寧澤蜈块,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布鉴腻,位于F島的核電站迷扇,受9級特大地震影響,放射性物質發(fā)生泄漏爽哎。R本人自食惡果不足惜蜓席,卻給世界環(huán)境...
    茶點故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望课锌。 院中可真熱鬧厨内,春花似錦、人聲如沸产镐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽癣亚。三九已至,卻和暖如春获印,著一層夾襖步出監(jiān)牢的瞬間述雾,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工兼丰, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留玻孟,地道東北人。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓鳍征,卻偏偏與公主長得像黍翎,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子艳丛,可洞房花燭夜當晚...
    茶點故事閱讀 45,675評論 2 359

推薦閱讀更多精彩內容