最近寫的文章都是創業類,好吧,今天好好寫寫技術類的文章!畢竟這幾天在速成IOS,看的是object-c,由於速成的很快,好累!好在現在基本已經入了點門道了,這才看的懂新人的代碼,才能提前感受代碼危機。對於IOS的速成口訣,回頭再分享,今天先分享一個簡單的抽象封裝! ...
前言:
最近寫的文章都是創業類,好吧,今天好好寫寫技術類的文章!
不過分享的不是IOS相關的文章,畢竟這幾天在速成IOS,看的是objective-c,由於速成的很快,好累!
好在現在基本已經入了點門道了,這才看的懂新人的代碼,才能提前感受代碼危機。
對於IOS的速成口訣,回頭再分享,今天先分享一個簡單的抽象封裝!
1:先看看問題
說明:通常對於界面佈局,有編寫代碼、Xib、Storyboard三種方式,而我看到新人寫的,是通過代碼佈局的。
看到的代碼是這樣的:
A:編寫UI的代碼已分離到新的類(.h .m文件)去,但仍然還是留下了不少代碼在ViewController中。
圖1:(在頁載入完後,調用了SetView方法,然後SetView方法里一堆和UI相關的代碼)
圖2:
2:想想怎麼優化
目標:讓每一個Controller都有一個對應的View的UI類,而Controller類里不要涉及UI創建的問題,儘量0入侵。
折騰過程:
這幾天學了下ObjectC的擴展類Category,覺的這東東有點搞頭。(和C#里的擴展類很像,但不同的是,object-C里擴展方法可以在基類里調到,這很神奇)
可惜擴展類不支持屬性,沒法把一些變數放到擴展類的屬性里,逼的要入侵Controller。
於是我又思考,折衷一下,用泛型定義一個共性的UIView,以避開入侵。
結果還是失敗了,objective-C的泛型不支持子類定義類型,唉~~~~
發現在C#輕鬆搞定的事,在object-c里不容易啊!!!
3:二次折衷的方法:
1:定義Controller的基類,定義一個方法,併在頁面載入時調用。
2:假設有LoginController,新建一個LoginView,繼承自UIView
3:一些UI相關的定義變數就寫在這裡了(.h文件)
4:在LoginView添加一個擴展類(不用新建類文件了,直接追加代碼就好了):
這裡擴展了一個方法叫initUI(等於重寫基類的方法)
5:這裡就是唯一二次折衷的地方,需要入侵Controller.h,定義一個UI屬性。
(之前是想通過把這個屬性定義到基類去,可惜泛型不支持子類指定類型)
6:接下來就是寫你的UI相關的代碼了。
總結:
1:手工寫的代碼的可視化,在調試階段才能看到,這是很悲催的結果。
2:個人不太建議手工佈局代碼的,開發效率也是個問題(當然你可以通過封裝一些UI代碼進一步提升下效率)。
3:不知道XCode沒有摺疊.h文件到.m文件下的插件呢?文件太多,切來切去太傷眼了。