Swift基础之Demo包含刷新,加载,网络请求,MVC
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
Swift基础之Demo包含刷新,加载,网络请求,MVC的更多相关文章
- [每天记录一个Bug]Cell中由于block加载网络请求产生的复用
Bug 出现场景: cell中使用加载图片的网络请求出现复用,截图如下: 复用原因: Cell Model中只有一个用户的uid,所有用户相关信息:例如头像\名称\信息等是通过 ...
- Swift语法基础入门四(构造函数, 懒加载)
Swift语法基础入门四(构造函数, 懒加载) 存储属性 具备存储功能, 和OC中普通属性一样 // Swfit要求我们在创建对象时必须给所有的属性初始化 // 如果没办法保证在构造方法中初始化属性, ...
- 分页插件思想:pc加载更多功能和移动端下拉刷新加载数据
感觉一个人玩lol也没意思了,玩会手机,看到这个下拉刷新功能就写了这个demo! 这个demo写的比较随意,咱不能当做插件使用,基本思想是没问题的,要用就自己封装吧! 直接上代码分析下吧! 布局: & ...
- Android UI--自定义ListView(实现下拉刷新+加载更多)
Android UI--自定义ListView(实现下拉刷新+加载更多) 关于实现ListView下拉刷新和加载更多的实现,我想网上一搜就一堆.不过我就没发现比较实用的,要不就是实现起来太复杂,要不就 ...
- 移动端tab滑动和上下拉刷新加载
移动端tab滑动和上下拉刷新加载 查看demo(请在移动端模式下查看) 查看代码 开发该插件的初衷是,在做一个项目时发现现在实现移动端tab滑动的插件大多基于swiper,swiper的功能太强大而我 ...
- ListView 刷新加载控件
1.MaterialRefreshLayout刷新加载: 导入依赖: compile 'com.cjj.materialrefeshlayout:library:1.3.0' 布局 <com.c ...
- jQuery Pjax – 页面无刷新加载,优化用户体验
pjax 是 HTML5 pushState 以及 Ajax 两项技术的简称,综合这两个技术可以实现在不刷新页面的情况下载入 HTML 到当前网页,带给你超快速的浏览器体验,而且有固定链接.标题以及后 ...
- android 在自定义的listview(有刷新加载项)列表中,数据过少时不能铺满整个屏幕时,header和footer同时显示问题
android 在自定义的listview(有刷新加载项)列表中,数据过少时,当刷新时,加载项也会显示,这是很头疼的一个问题,查阅了一些资料,总结了一个比较不错的方法: 原来代码: @Overrid ...
- js中对arry数组的各种操作小结 瀑布流AJAX无刷新加载数据列表--当页面滚动到Id时再继续加载数据 web前端url传递值 js加密解密 HTML中让表单input等文本框为只读不可编辑的方法 js监听用户的键盘敲击事件,兼容各大主流浏览器 HTML特殊字符
js中对arry数组的各种操作小结 最近工作比较轻松,于是就花时间从头到尾的对js进行了详细的学习和复习,在看书的过程中,发现自己平时在做项目的过程中有很多地方想得不过全面,写的不够合理,所以说啊 ...
随机推荐
- 前端性能监控系统 & 前端数据分析系统
前端监控系统 目前已经上线,欢迎使用! 背景:应工作要求,需要整理出前端项目的报错信息,尝试过很多统计工具,如: 腾讯bugly.听云.OneApm.还有一个忘记名字的工具. 因为各种原因,如: 统计 ...
- [HNOI 2015]开店
Description 风见幽香有一个好朋友叫八云紫,她们经常一起看星星看月亮从诗词歌赋谈到 人生哲学.最近她们灵机一动,打算在幻想乡开一家小店来做生意赚点钱.这样的 想法当然非常好啦,但是她们也发现 ...
- 4999: This Problem Is Too Simple!
Description 给您一颗树,每个节点有个初始值. 现在支持以下两种操作: C i x(0<=x<2^31) 表示将i节点的值改为x. Q i j x(0<=x<2^31 ...
- [bzoj1063][Noi2008]道路设计
来自FallDream的博客,未经允许,请勿转载,谢谢. Z国坐落于遥远而又神奇的东方半岛上,在小Z的统治时代公路成为这里主要的交通手段.Z国共有n座城市,一些城市之间由双向的公路所连接.非常神奇的是 ...
- MySQL插件实现浅析——插件的调用
一. MySQL中的动态插件 最初想到这个问题是在学习mysql半同步复制相关问题的时候,为何在mysql运行时install半同步插件并开启后就能起到作用,他是如何让事务停下来等待的.安装插件的时候 ...
- Nginx+Tomca+Redis实现负载均衡、资源分离、session共享
目标实现:Nginx作为负载均衡后端多Tomcat实例,通过Redis实现Session共享. 操作系统环境:CentOS 6.8 SSH:SecureCRT 其中 Nginx服务:80端口 Tomc ...
- easyui datagrid 排序问题
$('#dg').datagrid({ remoteSort:false,④ sortName:'sysfield', ① sortOrder:'desc',② columns:[[ {field ...
- log4j不生成日志文件的问题
直接看我的注解吧 注意地址的斜杠,还有地址别写什么相对地址了,这包太老了,服务器update一下兼容问题就出来了. #第一个参数定义达到什么程度就输出 第二第三....第N 定义输出的类型 #debu ...
- SQL注入原理及绕过安全狗
1.什么是SQL注入攻击 SQL注入攻击指的是通过构造特殊的输入作为参数插入到Web表单的输入域或页面请求的查询字符串,欺骗服务器执行恶意的SQL命令 http://www.xxx.com/list. ...
- 原生JS实现圆周运动
<body> <div id="ball" style="width:20px; height:20px; background:red; border ...