刚刚开始学习Swift,简单的写了个demo实现了MVC设计模式建UI页面,网络请求,刷新,文本提示框,使用闭包进行界面的反向传值,简单的选择器下面上效果图:
Simulator Screen Shot 2016年10月28日 下午1.02.03.png

Simulator Screen Shot 2016年10月28日 下午1.02.15.png
首页和第三页面用的都是自定义cell,MVC设计模式,首页是下写的假数据,第三上面的数据是网络请求数据,还有翻页效果,不过数据仅仅就只有2页,用的是Alamofire请求,本来想用AF的,结果发现Alamofire在Swift上很简单好用
let urlStr = "http://101.200.229.100:8080/ZHCS/houseKeeper/selectCompany.do?"
SVProgressHUD .show()
//设置超时
let config = NSURLSessionConfiguration.defaultSessionConfiguration()
config.timeoutIntervalForRequest = 5
Alamofire.request(.GET, urlStr,parameters: ["pageSize": "15","pageIndex":self.page]).responseJSON { (response) in
switch response.result {
case .Success:
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0)) {
dispatch_async(dispatch_get_main_queue(), {
SVProgressHUD.dismiss()
})
}
print(response)
//把得到的JSON数据转为字典
if let j = response.result.value as? NSDictionary{
//获取字典里面的key为数组
let Items1 = j.valueForKey("info")as! NSDictionary
let Items = Items1.valueForKey("listItems")as! NSArray
if self.page == 0{
self.dataArr = []
}
for dic in Items {
let status = AddressModel(dict:dic as! [String : AnyObject])
self.dataArr.append(status)
}
//上啦刷新判断下一页是否还有数据
if Items.count == 0 {
SVProgressHUD.showInfoWithStatus("没有更多数据了")
self.page = self.page - 1
}else{
SVProgressHUD.showSuccessWithStatus("数据加载成功")
}
self.tableView.reloadData()
}
SVProgressHUD.dismissWithDelay(1.0)
case .Failure(let error):
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0)) {
dispatch_async(dispatch_get_main_queue(), {
SVProgressHUD.dismiss()
})
}
print(error)
}
}
}
不用像AF一样在进行封装,如果想用MVVM设计模式的话,网络请求就要自己放在一个model里面就可以了,再利用闭包从控制器中调用网络请求代码块即可
我的里面试用了闭包反向传值,总结了一下闭包的方法,感觉好麻烦,就和OC中的代理一样麻烦,步骤众多,不过Swift中代理变得好简单
/*
1.首先在要传值的页面 定义
typealias TestBlock = (model: 要传数据的类型)->()
2.生成
var blo: TestBlock?
3.在需要的地方调用
self.blo?(model: 要传的数据)
4.然后在被传值的页面
创建传值页面,然后:
testVC.blo = { (model) -> Void in
获得了model
}
*/
具体的还是看代码吧文字叙述慢慢补充.git地址,点击下载