swift post 网络请求

oneviewconeroller


import UIKit

//屏幕的宽

var scrW = UIScreen.main.bounds.size.width

//屏幕的高

var scrH = UIScreen.main.bounds.size.height

class OneViewController: BaseViewController,UITableViewDelegate,UITableViewDataSource {





    //MARK:--------------------属性的声明------------------

    var tbv:UITableView?

    vartbvData:[Student]?

    var segment:UISegmentedControl?

    var titles = ["推荐新闻","实时对话","行情分析","专栏"]

    varonetitle = ["1","2","3","4"]

    //下拉刷新控件

    var mjHeader:MJRefreshHeaderView?


    //MARK:--------------------UI创建------------------

    funcinitUI() {

        //创建segment分段控制器

        self.segment = UISegmentedControl.init(items: titles)


        //设置位置

        self.segment?.frame=CGRect.init(x:0, y:0, width:scrW, height:40)


        //设置默认选中的下标

        self.segment?.selectedSegmentIndex = 0


        //自动获取第一个标题的新闻数据

        self.getURLData(titleIndex:onetitle[0])


        //设置触发方法

        self.segment?.addTarget(self, action:#selector(segmentDidChange(seg:)), for: .valueChanged)


        self.segment?.tintColor = UIColor.black


        //添加到view子视图

        self.view.addSubview(self.segment!)




        //实例化表格

        self.tbv=UITableView.init(frame:CGRect.init(x:0, y:40, width:scrW, height:scrH-40), style: .plain)



        //设置代理和数据源

        self.tbv?.delegate=self

        self.tbv?.dataSource=self


        //添加到子视图

        self.view.addSubview(self.tbv!)



        //实例化下拉刷新的控件

        self.mjHeader = MJRefreshHeaderView.init(scrollView:self.tbv!)


        //设置刷新的回调的闭包

        self.mjHeader?.beginRefreshingBlock = {refreshViewin


        }


        self.tbv?.rowHeight=150

    }



    //MARK:--------------------UI控件的触发方法------------------

    @objcfuncsegmentDidChange(seg:UISegmentedControl) ->Void{

        //根据选中的分段下标获取对应的标题,获取网络数据

        self.getURLData(titleIndex:titles[seg.selectedSegmentIndex])

    }


    //MARK:-------------------viewDidLoad-------------------

    overridefuncviewDidLoad() {

        super.viewDidLoad()

         self.initUI()






    }



    //MARK:------------------代理和数据源的实现的方法-------------------

    functableView(_tableView:UITableView, numberOfRowsInSection section:Int) ->Int{

        ifletcount =self.tbvData?.count{

            returncount

        }

        return0

    }


    functableView(_tableView:UITableView, cellForRowAt indexPath:IndexPath) ->UITableViewCell{

       //定义一个标识符

        letidentifier ="Mycell"

        varcell = tableView.dequeueReusableCell(withIdentifier: identifier)as?StudentTableViewCell


        ifcell ==nil{

            cell =StudentTableViewCell.init(style: .subtitle, reuseIdentifier: identifier)

        }

        ifletoneNew =self.tbvData?[indexPath.row]{

            //图片

            cell?.imgview?.sd_setImage(with:URL.init(string: oneNew.img), completed:nil)


            //标题

            cell?.titleLabel?.text = oneNew.title


            //作者

            cell?.author?.text ="作者\(oneNew.author)"


            //阅读量

            cell?.readNum?.text ="阅读量:\(oneNew.read_num)"

        }



        returncell!

    }


    //MARK:--------------------获取网络请求数据------------------

    funcgetURLData(titleIndex:String) ->Void{

        //转动指示器

        UIApplication.shared.isNetworkActivityIndicatorVisible = true


        //网络请求,网址字符串拼接

        let url = URL.init(string: "http://buluokes.huimor.com/api")


        //创建请求对象,同时设置缓存策略及超时时长

        varreq =URLRequest.init(url: url!, cachePolicy: .reloadRevalidatingCacheData, timeoutInterval:5.0)


        //设置POST请求

        req.httpMethod="POST"


        //把请求参数拼接成字符串

        let paramStr = "method=app.news.getarticlelist&class_id\(titleIndex)&page=1&user_token="


        //将参数字符串转换为二进制Data数据

        letparamData = paramStr.data(using: .utf8)


        //将参数二进制数据放入请求体中

        req.httpBody= paramData


        //正式请求网络数据,使用URLsession

        lettask =URLSession.shared.dataTask(with: req) { (data, response, error)in

            //回到UI主线程停止转动指示器

            DispatchQueue.main.async {

                UIApplication.shared.isNetworkActivityIndicatorVisible = false

                self.mjHeader?.endRefreshing()

            }


            //如果服务器错误,给客户提示

            iferror !=nil{

                DispatchQueue.main.async {

                   self.view.showMBAlert(msg:"服务器错误")

                }

                return

            }


            //如果连接成功,将二进制数据转换为数组或字典

            letjsonData =try?JSONSerialization.jsonObject(with: data!, options: .allowFragments)


            //如果转换失败

            if  jsonData  ==nil{

                DispatchQueue.main.async {

                    self.view.showMBAlert(msg:"json数据解析错误")

                }

                return

            }


            //t如果转换成功,将数据转换为字典类型

            letjsonDic = jsonDataas!NSDictionary


            //获取code值

            letoneCode = jsonDic["code"]as!Int


            //如果code的值不为200 ,表示有错误发生,给出用户提示

            if  oneCode !=200{

                DispatchQueue.main.async {

                    self.view.showMBAlert(msg:"code值不是200")

                }

                return

            }


            //如果数据都正确,做JSON解析

            letresultDic = jsonDic["data"]as!NSDictionary

            letdataArr = resultDic["list"]as!NSArray

            print(dataArr)


            //将dataArr转换为News数组,赋值给表格数据数组

            self.tbvData = Student.createNewsArr(withDataArr: dataArras! [Any])


            //刷新表格

            DispatchQueue.main.async {

                self.tbv?.reloadData()

            }

        }

        task.resume()

    }

}



Student.h

#import

NS_ASSUME_NONNULL_BEGIN

@interfaceStudent :NSObject

@property(nonatomic,strong)NSString * type;

@property(nonatomic,strong)NSString * id;

@property(nonatomic,strong)NSString * img;

@property(nonatomic,strong)NSString * title;

@property(nonatomic,strong)NSString * read_num;

@property(nonatomic,strong)NSString * content;

@property(nonatomic,strong)NSString * author;

@property(nonatomic,strong)NSString * create_time;

//把得到的json数据中的data数组转换为Student数组

+(NSArray*)createNewsArrWithDataArr:(NSArray*)dataArr;

@end

NS_ASSUME_NONNULL_END



Student.m


#import "Student.h"

@implementation Student

+(NSArray*)createNewsArrWithDataArr:(NSArray*)dataArr{

    //定义可变数组,用于储存Student对象

    NSMutableArray * newsArr = [[NSMutableArray alloc]init];


    //遍历dataArr中的每个字典

    for(NSDictionary* dicindataArr){

        //将每个dic转化为Student对象

        Student* one = [[Studentalloc]init];


        //对one的属性赋值

        [onesetValuesForKeysWithDictionary:dic];


        //把每次循环生成的one对象加入到数组中

        [newsArraddObject:one];

    }

    //在循环外,将newsArr返回

    return[newsArrcopy];

}

@end


AlertView.swift

import UIKit

extension  UIView {

   //显示MB提示框

    funcshowMBAlert(msg:String) ->Void{

        //实例化MB

        letalert = MBProgressHUD.init(view:self)


        //设置提示为文本样式

        alert?.mode = MBProgressHUDModeText


        //设置隐藏时自动从父视图移除

        alert?.removeFromSuperViewOnHide =true


        //设置显示的提示文本

        alert?.labelText = msg


        //添加为子视图

        self.addSubview(alert!)


        //显示提示框

        alert?.show(true)


        //设置几秒自动隐藏

        alert?.hide(true, afterDelay:3.0)

    }

}

StudentTableViewCell.swift



import UIKit

classStudentTableViewCell:UITableViewCell{

    //图片视图

    varimgview:UIImageView?


    //标题标签

    vartitleLabel:UILabel?


    //作者标签

    varauthor:UILabel?


    //阅读量

    varreadNum:UILabel?


    funcinitUI() {

        //图片

        self.imgview=UIImageView.init(frame:CGRect.init(x:5, y:5, width:140, height:140))

        self.contentView.addSubview(self.imgview!)



        //标题

        self.titleLabel=UILabel.init(frame:CGRect.init(x:145, y:5, width:scrW-155, height:50))


        self.titleLabel?.font=UIFont.systemFont(ofSize:20.0)


        self.contentView.addSubview(self.titleLabel!)



        //作者标签

        self.author=UILabel.init(frame:CGRect.init(x:145, y:80, width:150, height:40))


        self.author?.font=UIFont.systemFont(ofSize:17.0)


        self.author?.textColor = UIColor.gray


        self.contentView.addSubview(self.author!)


        //阅读量

        self.readNum=UILabel.init(frame:CGRect.init(x:300, y:80, width:150, height:40))


        self.readNum?.font=UIFont.systemFont(ofSize:17.0)


        self.readNum?.textColor = UIColor.gray


        self.contentView.addSubview(self.readNum!)



    }

    overrideinit(style:UITableViewCell.CellStyle, reuseIdentifier:String?) {

        super.init(style: style, reuseIdentifier: reuseIdentifier)

        self.initUI()

    }


    requiredinit?(coder aDecoder:NSCoder) {

        fatalError("init(coder:) has not been implemented")

    }


    overridefuncawakeFromNib() {

        super.awakeFromNib()

        // Initialization code

    }

    overridefuncsetSelected(_selected:Bool, animated:Bool) {

        super.setSelected(selected, animated: animated)

        // Configure the view for the selected state

    }

}



AppDelegate.swift


  let oneVC = OneViewController()

        letoneNav =UINavigationController.init(rootViewController: oneVC)

        oneNav.tabBarItem=UITabBarItem.init(title:"新闻", image:UIImage.init(named:""), tag:1)

        oneVC.navigationItem.title = "我的新闻"



        lettwoVC =TwoViewController()

        lettwoNav =UINavigationController.init(rootViewController: twoVC)

        twoNav.tabBarItem=UITabBarItem.init(title:"娱乐", image:UIImage.init(named:""), tag:2)

        twoVC.navigationItem.title = "我的娱乐"



        let tbc = UITabBarController()

        tbc.viewControllers= [oneNav,twoNav]

        self.window?.rootViewController = tbc

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343

推荐阅读更多精彩内容