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的更多相关文章

  1. [每天记录一个Bug]Cell中由于block加载网络请求产生的复用

    Bug 出现场景:   cell中使用加载图片的网络请求出现复用,截图如下:         复用原因:   Cell Model中只有一个用户的uid,所有用户相关信息:例如头像\名称\信息等是通过 ...

  2. Swift语法基础入门四(构造函数, 懒加载)

    Swift语法基础入门四(构造函数, 懒加载) 存储属性 具备存储功能, 和OC中普通属性一样 // Swfit要求我们在创建对象时必须给所有的属性初始化 // 如果没办法保证在构造方法中初始化属性, ...

  3. 分页插件思想:pc加载更多功能和移动端下拉刷新加载数据

    感觉一个人玩lol也没意思了,玩会手机,看到这个下拉刷新功能就写了这个demo! 这个demo写的比较随意,咱不能当做插件使用,基本思想是没问题的,要用就自己封装吧! 直接上代码分析下吧! 布局: & ...

  4. Android UI--自定义ListView(实现下拉刷新+加载更多)

    Android UI--自定义ListView(实现下拉刷新+加载更多) 关于实现ListView下拉刷新和加载更多的实现,我想网上一搜就一堆.不过我就没发现比较实用的,要不就是实现起来太复杂,要不就 ...

  5. 移动端tab滑动和上下拉刷新加载

    移动端tab滑动和上下拉刷新加载 查看demo(请在移动端模式下查看) 查看代码 开发该插件的初衷是,在做一个项目时发现现在实现移动端tab滑动的插件大多基于swiper,swiper的功能太强大而我 ...

  6. ListView 刷新加载控件

    1.MaterialRefreshLayout刷新加载: 导入依赖: compile 'com.cjj.materialrefeshlayout:library:1.3.0' 布局 <com.c ...

  7. jQuery Pjax – 页面无刷新加载,优化用户体验

    pjax 是 HTML5 pushState 以及 Ajax 两项技术的简称,综合这两个技术可以实现在不刷新页面的情况下载入 HTML 到当前网页,带给你超快速的浏览器体验,而且有固定链接.标题以及后 ...

  8. android 在自定义的listview(有刷新加载项)列表中,数据过少时不能铺满整个屏幕时,header和footer同时显示问题

    android  在自定义的listview(有刷新加载项)列表中,数据过少时,当刷新时,加载项也会显示,这是很头疼的一个问题,查阅了一些资料,总结了一个比较不错的方法: 原来代码: @Overrid ...

  9. js中对arry数组的各种操作小结 瀑布流AJAX无刷新加载数据列表--当页面滚动到Id时再继续加载数据 web前端url传递值 js加密解密 HTML中让表单input等文本框为只读不可编辑的方法 js监听用户的键盘敲击事件,兼容各大主流浏览器 HTML特殊字符

    js中对arry数组的各种操作小结   最近工作比较轻松,于是就花时间从头到尾的对js进行了详细的学习和复习,在看书的过程中,发现自己平时在做项目的过程中有很多地方想得不过全面,写的不够合理,所以说啊 ...

随机推荐

  1. tmux 终端复用详解

    tmux是什么 我们在linux服务器上的工作一般都是通过一个远程的终端连接软件连接到远端系统进行操作,例如使用xshell或者SecureCRT工具通过ssh进行远程连接.在使用过程中,如果要做比较 ...

  2. UVALive - 3027:Corporative Network

    加权并查集 #include<cstdio> #include<cstdlib> #include<algorithm> #include<cstring&g ...

  3. NOIP2015-D2T3运输计划

    题目背景 公元 2044 年,人类进入了宇宙纪元. 题目描述 L 国有 n 个星球,还有 n-1 条双向航道,每条航道建立在两个星球之间,这 n-1 条航道连通了 L 国的所有星球. 小 P 掌管一家 ...

  4. 【BZOJ1087】【SCOI2005】互不侵犯King

    Description 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上 左下右上右下八个方向上附近的各一个格子,共8个格子. Input 只有一行, ...

  5. 【BZOJ1036】【ZJOI2008】数的统计

    接着找树剖的题...传送门(点我) 题意:给你一棵无根树,有三种操作:查询树上2点路径的点权和/最大点权:更改某点的点权. 解题思路:树链剖分裸题,我采用了常数较小的zkw线段树维护剖下来的树(毕竟线 ...

  6. bzoj 1875: [SDOI2009]HH去散步

    Description HH有个一成不变的习惯,喜欢饭后百步走.所谓百步走,就是散步,就是在一定的时间 内,走过一定的距离. 但 是同时HH又是个喜欢变化的人,所以他不会立刻沿着刚刚走来的路走回. 又 ...

  7. bzoj1043[HAOI2008]下落的圆盘 计算几何

    1043: [HAOI2008]下落的圆盘 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1598  Solved: 676[Submit][Stat ...

  8. [APIO2013]

    A.机器人 题目大意:给定一个n*m的地图,有一些障碍物和k个机器人,你每次可以选择一个机器人往任意一个方向推,遇到转向器会转向,两个编号相邻的机器人可以合并,求最少推多少次可以全部合并. $n,m\ ...

  9. Linux学习之CentOS(十三)-----磁盘管理之 磁盘与目录的容量(转) df 与du 命令

    磁盘与目录的容量 现在我们知道磁盘的整体数据是在 superblock 区块中,但是每个各别文件的容量则在 inode 当中记载的. 那在文字接口底下该如何叫出这几个数据呢?底下就让我们来谈一谈这两个 ...

  10. springboot解决跨域问题(Cors)

    1.对于前后端分离的项目来说,如果前端项目与后端项目部署在两个不同的域下,那么势必会引起跨域问题的出现. 针对跨域问题,我们可能第一个想到的解决方案就是jsonp,并且以前处理跨域问题我基本也是这么处 ...