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



  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hbblzjy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值