總是斷斷續續的學習一些swift知識,在實際開發中也未使用過swift來開發一款app。故將平時的學習筆記留在這里,勉勵自己。在以后的發展中,swift必將成為翹楚。
- 以下筆記是基于Swift4版本:
- 關于swift三方庫的介紹請看OC&Swift三方庫
-
懶加載:
lazy var tableView: UITableView = {
let tab = UITableView(frame: UIScreen.main.bounds, style: UITableViewStyle.plain)
tab.delegate = self
tab.dataSource = self
tab.register(UITableViewCell.classForCoder(), forCellReuseIdentifier: "123")
return tab
}()
-
set和get方法
//cell上加載數據,用到了Kingfisher
var teacherModel: ContentModel! {
//didSet可以來復制,willSet,
didSet {
let url = URL.init(string: teacherModel.headUrl)
self.iconImageView.kf.setImage(with: url)
self.nameLabel.text = teacherModel.nickname
}
}
var sideLength: Double
var perimeter: Double {
get {
return 3.0 * sideLength
}
set {
sideLength = newValue / 3.0
}
}
var traingle: Square {
willSet {
square.sideLength = newValue.sideLength
}
}
-
協議與代理
//聲明協議,
protocol ResourceButtonResponseDelegate {
optional func responseButton(button:UIButton)
}
//聲明代理屬性
var delegate:ResourceButtonResponseDelegate?
//傳值
if let dele = self.delegate {
dele.responseButton(button: button)
}
//成為代理
header.delegate = self
//代理方遵守協議并完成協議
extension ViewController: ResourceButtonResponseDelegate {
func responseButton(button: UIButton) {
print(button.tag)
}
}
-
block(閉包),typealias別名
//聲明屬性:名稱(參數:參數類型,...) ->返回類型
var responseBlock:((_ index:Int) ->Void)?
//需要的時候傳值
if let block = self.responseBlock {
block(index)
}
//接收傳值
header.responseBlock = { index in
print(index)
}
//閉包別名
typealias ResponseBlock = (_ index:Int)->Void
-
swift排序??,再也不用寫冒泡啦
var numbers = [20, 19, 7, 12, 3, 4, 28, 17]
let sortNum = numbers.sorted { $0 > $1 }
-
selector方法
//添加方法:#selector(類名:方法名)
btn.addTarget(self, action: #selector(HomeHeaderView.clickResourceButton(button:)), for: .touchUpInside)
//方法
@objc func clickResourceButton(button: UIButton) {
//do something
}
-
UIImage:可以直接引入圖片名稱來顯示圖片。直接敲圖片名稱:只能為英文名稱
banner.png
-
網絡請求:需用到Alamofire:發起請求、SwiftyJSON:解析json很容易很安全、ObjectMapper:json轉模型
import Alamofire
import SwiftyJSON
//encoding:JSONEncoding.default,headers:headers這樣才是接收json數據。
let headers: HTTPHeaders = ["Accept": "application/json"]
typealias SuccessBlock = (_ data: JSON)->Void
typealias FailureBlock = (_ error: String)->Void
class Network: NSObject {
class func request(url: String,
method: HTTPMethod,
parameters: Parameters,
success: @escaping SuccessBlock,
failure: @escaping FailureBlock) {
Alamofire.request(url,
method: method,
parameters: parameters,
encoding: JSONEncoding.default,
headers: headers).responseJSON { (response) in
//SwiftyJSON
switch response.result {
case .success(let value):
let json = JSON(value)
print(json)
success(json)
case .failure(let error):
print(error)
failure(error.localizedDescription)
}
}
}
class func teacherRecommendRequest(_ success: @escaping SuccessBlock, _ failure: @escaping FailureBlock) {
let para: Parameters = ["page":0,"pageSize":5]
self.request(url: baseUrl+teacherRecommend,
method: HTTPMethod.post,
parameters: para,
success: success,
failure: failure);
}
}
ObjectMapper:Swift里轉模型稍微復雜一點,手動映射。
建立模型
import UIKit
import ObjectMapper
class ResultModel: Mappable {
var code: Int?
var msg: String?
var data: Any!
required init?(map: Map) {
}
// Mappable
func mapping(map: Map) {
code <- map["code"]
msg <- map["msg"]
data <- map["data"]
}
}
import UIKit
import ObjectMapper
class DataModel: Mappable {
var number: Int = -1
var numberOfElements: Int = 0
var sort: Any?
var totalPages: Int = 0
var size: Int = 0
var last: Bool = false
var totalElements: Int = 0
var first: Bool = false
var content: [ContentModel]!
required init?(map: Map) {
}
func mapping(map: Map) {
number <- map["number"]
content <- map["content"]
numberOfElements <- map["numberOfElements"]
sort <- map["sort"]
totalPages <- map["totalPages"]
size <- map["size"]
last <- map["last"]
totalElements <- map["totalElements"]
first <- map["first"]
}
}
轉模型:網絡求得的JSON數據。
Network.teacherRecommendRequest({ (result) in
print("data:\(result)")
//轉模型
let res = ResultModel(JSONString: result.rawString()!)
if let data = res?.data {
print(data)
let json = JSON(data)
//將data再轉模型
print((DataModel(JSONString: json.rawString()!))!.content[0].info ?? "")
}
}) { (error) in
print("error:\(error)")
}