Swift中有一个Alamofire第三方是进行网络请求的,它是AFNetworking的作者写的Swift形式,今天先介绍一下,利用pod导入AFNetworking,SVProgressHUD,MJRefresh等第三方实现刷新数据、加载更多、网络请求,同时使用了MVC的模式进行界面搭建,随后研究Alamofire实现网络请求的功能,再分享给大家。。。。
本文有两个界面,首界面直接使用的AFNetworking进行网络请求,然后界面展示
首界面创建表格:
self.myTableView = UITableView.init(frame: CGRect.init(x: 0, y: 0, width: SCREEN_W, height: SCREEN_H), style: UITableViewStyle.plain);
self.myTableView.delegate = self;
self.myTableView.dataSource = self;
self.myTableView.rowHeight = 80;
self.myTableView.tableHeaderView = UIView.init();
self.myTableView.tableFooterView = UIView.init();
self.view.addSubview(self.myTableView);
//注册Cell
self.myTableView.register(MyCellTableViewCell.self, forCellReuseIdentifier: "myCell");
// Nib 注册
//self.tableView.registerNib(UINib(nibName: "MyCellTableViewCell", bundle: nil), forCellReuseIdentifier: "myCell")
//添加下拉刷新
self.myTableView.mj_header = MJRefreshNormalHeader(refreshingBlock: {
//数据加载
self.pageIndexI = 1;
self.dataHttpRequest(pageIndexStr: NSString.init(format: "%d", self.pageIndexI));
});
//设置启动即刷新
//self.myTableView.mj_header.beginRefreshing();
然后进行网络请求方法:
//MARK:-------AFNetworking基本的数据请求形式(未封装的方法)
func dataHttpRequest(pageIndexStr:NSString) {
SVProgressHUD.show(withStatus: "正在加载");
if pageIndexStr.isEqual(to: "1") {
self.dataArray.removeAllObjects();
}
let urlStr = "http://www.healthmanage.cn/android/hrsBabyAction_loadHrsBabyHealth.action";
let paramsDic = ["userId":"38567","pagesize":"8","pageIndex":pageIndexStr];
//AFNetworking使用POST请求
let sessionManager = AFHTTPSessionManager.init();
sessionManager.responseSerializer.acceptableContentTypes?.insert("text/plain");
sessionManager.post(urlStr, parameters: paramsDic, progress: nil, success: { (_, responseObject) -> Void in
//print("输出此时的数据请求结果......\(responseObject)");
SVProgressHUD.dismiss(withDelay: 1);
self.myTableView.mj_header.endRefreshing();
//守卫语句,用于判断不符合条件时安全退出,而不是crash
guard (responseObject as? NSDictionary) != nil else{
print("返回数据为nil,或者 类型不匹配");
return;
};
let resultDic = responseObject as! NSDictionary;
let successB = resultDic["success"] as! Bool;
if(successB){
//如果返回有值
let itemArray = resultDic["ITEMS"] as! NSArray;
if(self.myTableView.mj_footer != nil)
{
self.myTableView.mj_footer.endRefreshing();
}
else
{
//判断数组数量和page,如果符合条件就添加上拉加载
if(itemArray.count == 8 && pageIndexStr.isEqual(to: "1"))
{
self.myTableView.mj_footer = MJRefreshBackNormalFooter(refreshingBlock:{ () -> Void in
self.pageIndexI = self.pageIndexI+1;
self.dataHttpRequest(pageIndexStr: NSString.init(format: "%d", self.pageIndexI));
})
}
}
for dic in itemArray {
//因为数组中是:[String:AnyObject]字典类型,所以不能使用as!NSDictionary,我是这么理解的,不知道对不对
let itemDic = dic as! [String:AnyObject];
self.dataArray.add(itemDic);
}
self.myTableView.reloadData();
}
else
{
//请求无数据NOVALUE情况
if self.dataArray.count>0{
self.myTableView.mj_footer.endRefreshing();
self.myTableView.mj_footer = nil;
}
}
}) { (_, error) in
print("请求数据错误报告...........\(error)");
SVProgressHUD.showError(withStatus: "网络请求错误");
}
首界面完成后进行第二层界面的设计,采用MVC的结构进行样式创建:
创建表格界面,然后使用数据请求工具和Model进行数据的解析,然后在Cell中进行Model数据的展示
数据请求工具方法:
//创建请求数据的工具方法
//参数说明:mType:方式 URLString:url parametersDic:参数 success:成功闭包结构 failure:失败闭包结构
func urlRequestTool(mType:MethodTypes,URLString:String,parametersDic:Dictionary<String,Any>?,successComplete: @escaping SuccessClosure,failureComplete:@escaping FailureClosure) {
SVProgressHUD.show(withStatus: "正在加载");
if mType == .GET {
self.get(URLString, parameters: parametersDic, progress: nil, success: { (_, respData) -> Void in
//返回数据
SVProgressHUD.dismiss(withDelay: 1);
successComplete(respData);
}, failure: { (_, err) in
//返回错误
SVProgressHUD.dismiss(withDelay: 1);
failureComplete(err);
})
}else{
self.post(URLString, parameters: parametersDic, progress: nil, success: { (_, respData) in
//返回数据
SVProgressHUD.dismiss(withDelay: 1);
successComplete(respData);
}, failure: { (_, err) in
//返回错误
SVProgressHUD.dismiss(withDelay: 1);
failureComplete(err);
})
}
}
Model类:
class MyDic: NSObject {
var petNameStr:String!;
var genderIdStr:String!;
var birthdayStr:String!;
init(dict:[String:AnyObject]) {
super.init();
self.petNameStr = dict["petName"] as! String!;
self.genderIdStr = dict["genderId"] as! String!;
self.birthdayStr = dict["birthday"] as! String!;
}
}
Cell中数据展示:
func setMyDicModel(dataModel:MyDic)
{
self.nameLabel.text = dataModel.petNameStr;
let sexStr = dataModel.genderIdStr;//也可以转成NSString使用
//NSString 有一个方法isEqualToString 方法用来判断两个字符串是否完全相等,String没有这个方法,但是因为String是值类型所以可以直接用 == 判断是否完全相等。
if sexStr == "1" {
self.sexImgView.image = UIImage.init(named: "baby_sex_boy");
self.headImgView.image = UIImage.init(named: "baby_default_boy");
}
else
{
self.sexImgView.image = UIImage.init(named: "baby_sex_girl");
self.headImgView.image = UIImage.init(named: "baby_default_girl");
}
self.birthDayLabel.text = NSString.init(format: "生日:%@",dataModel.birthdayStr) as String;
}
效果图:
具体代码讲解看源码中的文字注释,如果不错请点赞,谢谢,转载请注明出处。。。。:https://github.com/hbblzjy/Swift-RefreshHTTP.git