最近在用Swift寫一個開源應(yīng)用疑苫,把一些在Swift中常用的庫列出來,方便學(xué)習(xí)Swift的同學(xué)使用纷责。
推薦一:代碼布局 Cartography
Cartography是類似于OC中Masonry代碼布局的庫捍掺,通過使用它,可以很方便快捷的進(jìn)行界面的布局再膳,使用也很簡單,類似于Masonry乡小。例如以下布局:
若實現(xiàn)以上布局只需要通過以下代碼即可完成布局
func CartographyTest(){
let view1 = UIView.init();
let view2 = UIView.init();
self.view.addSubview(view1);
self.view.addSubview(view2);
constrain(view1,view2) { (view1,view2) in
view1.top == (view1.superview?.top)!;
view1.leading == (view1.superview?.leading)! + 54;
view1.width == 100;
view1.height == 100;
view2.top == (view2.superview?.top)!;
view2.trailing == (view2.superview?.trailing)! - 48;
view2.width == 112;
view2.height == 146;
}
}
推薦二:網(wǎng)絡(luò)請求庫 Alamofire(Swift中的AF)
對于使用OC開發(fā)的同學(xué)一定都對AFNetworking很熟悉吧,在Swift中該作者也特意封裝了Swift版的AF饵史,它就是Alamofire,對網(wǎng)絡(luò)的請求也是極為方便的。使用方法也很簡單:
//MARK:網(wǎng)絡(luò)請求
func netRequest() {
let parameter:Parameters = ["action":"mainList_NewVersion",
"currentPageIndex":"\(page)"];
Alamofire.request(CommonURL + TopicHomePage, method: .post, parameters: parameter, encoding: URLEncoding.httpBody).responseJSON { (response) in
print("Request: \(response.request)")
print("Response: \(response.response)")
print("Error: \(response.error)")
if let value = response.result.value {
let tempModel = TopicIndexModel.init(fromJson: JSON(value));
//將數(shù)據(jù)模型放入對應(yīng)的model中
if(self.page == 0){
self.topicRootModel = tempModel;
}else{
self.topicRootModel?.result.append(contentsOf: tempModel.result);
}
self.tableView?.reloadData();
self.tableView?.mj_footer.endRefreshing();
self.tableView?.mj_header.endRefreshing();
self.page += 1;
}
}
}
推薦三:模型轉(zhuǎn)換 SwiftyJSON
在Swift中,對于JSON的處理由于optional的引入胳喷,要手動從AnyObject(也就是Objective-C的id)取得數(shù)據(jù)湃番,顯得頗為麻煩,例如官方給出的例子:
let jsonObject : AnyObject! = NSJSONSerialization.JSONObjectWithData(dataFromTwitter, options: NSJSONReadingOptions.MutableContainers, error: nil);
if let statusesArray = jsonObject as? NSArray{
if let aStatus = statusesArray[0] as? NSDictionary{
if let user = aStatus["user"] as? NSDictionary{
if let userName = user["name"] as? NSDictionary{
//好累吭露,我就取個數(shù)據(jù)寫了這么多吠撮。
}
}
}
}
此時如果通過SwiftJSON使用來取數(shù)據(jù),如下:
let json = JSON(data: dataFromNetworking)
if let userName = json[0]["user"]["name"].string{
//就這么簡單取到了讲竿。
}
其實這個不僅取數(shù)據(jù)變得簡單了泥兰,而且創(chuàng)建模型Model也變得異常的簡單。有點類似于MJExtention
的使用题禀。
實例使用如下:
//
// Category.swift
//
// Create by lcc on 13/2/2017
// Copyright ? 2017. All rights reserved.
import Foundation
import SwiftyJSON
class Category : NSObject, NSCoding{
var createDate : String!
var enName : String!
var id : String!
var img : String!
var name : String!
var order : Int!
init(fromJson json: JSON!){
if json.isEmpty{
return
}
createDate = json["createDate"].stringValue
enName = json["enName"].stringValue
id = json["id"].stringValue
img = json["img"].stringValue
name = json["name"].stringValue
order = json["order"].intValue
}
func toDictionary() -> [String:Any]
{
var dictionary = [String:Any]()
if createDate != nil{
dictionary["createDate"] = createDate
}
if enName != nil{
dictionary["enName"] = enName
}
if id != nil{
dictionary["id"] = id
}
if img != nil{
dictionary["img"] = img
}
if name != nil{
dictionary["name"] = name
}
if order != nil{
dictionary["order"] = order
}
return dictionary
}
@objc required init(coder aDecoder: NSCoder)
{
createDate = aDecoder.decodeObject(forKey: "createDate") as? String
enName = aDecoder.decodeObject(forKey: "enName") as? String
id = aDecoder.decodeObject(forKey: "id") as? String
img = aDecoder.decodeObject(forKey: "img") as? String
name = aDecoder.decodeObject(forKey: "name") as? String
order = aDecoder.decodeObject(forKey: "order") as? Int
}
func encode(with aCoder: NSCoder)
{
if createDate != nil{
aCoder.encode(createDate, forKey: "createDate")
}
if enName != nil{
aCoder.encode(enName, forKey: "enName")
}
if id != nil{
aCoder.encode(id, forKey: "id")
}
if img != nil{
aCoder.encode(img, forKey: "img")
}
if name != nil{
aCoder.encode(name, forKey: "name")
}
if order != nil{
aCoder.encode(order, forKey: "order")
}
}
}
而創(chuàng)建Model的實例如下所示:
//從json中直接轉(zhuǎn)換對應(yīng)的Model
let tempModel = Category.init(fromJson: JSON(value));
推薦四:圖片加載庫 Kingfisher(類似于SDWebImage)
對于App來說,圖片的加載以及相關(guān)的緩存是很重要的,而SDWebImage
也正是為此而存在骑篙,在Swift中泣洞,有一個非常不錯的圖片加載的庫,就是Kingfisher了秀仲,該庫的使用與SDWebImage
類似融痛,例如官方介紹:
let url = URL(string: "url_of_your_image")
imageView.kf.setImage(with: url)
推薦五:使用橋接模式將OC中的優(yōu)秀庫放入Swfit中開發(fā)
這里就直接列舉一個實例吧,以AFNetworking
為例神僵,如果我們使用pod安裝對應(yīng)的OC中的類庫雁刷,先將OC與Swift的橋接模式打開,然后導(dǎo)入對應(yīng)的庫即可保礼,如下:
注:可能導(dǎo)入的時候總是提示沒有對應(yīng)的module
沛励,此時可以通過clean項目來解決
總結(jié)
以上幾個庫都是Swift開發(fā)中常用的一些庫,可能還有一些沒有提及到的庫氓英,后續(xù)還會繼續(xù)添加侯勉,對于這些庫的安裝,推薦使用pod
安裝,pod
的內(nèi)容如下:
platform :ios, '8.0'
use_frameworks!
pod 'Cartography', '~> 1.0.1'
pod 'Kingfisher', '~> 3.4.0'
target 'your project name' do
pod 'SwiftyJSON', '~> 3.1.4'
pod 'Alamofire', '~> 4.3.0'
end