iOS Swift4.0 获取网络数据

Swift 网络数据请求与解析:

1、创建一个继承于NSObject的类URLService,在URLService中写Get请求。定义成一个方法方便调用

funcgetNewsData(channel:String,startNum:Int,completion:@escaping(Any,Bool)->(Void)) ->Void{

        // 使用Get请求数据

        // (1)网址字符串

        var urlStr = "网址字符串"

        // (2)转码

        urlStr = urlStr.addingPercentEncoding(withAllowedCharacters:.urlFragmentAllowed)!

        // (3)封装为URL对象

        varurl =URL(string: urlStr)

        // (4)封装为URLRequest对象

        letreq =URLRequest(url: url!, cachePolicy:.reloadIgnoringCacheData, timeoutInterval:5.0)

        // (5)URLSession请求网络数据

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

            // 如果发生错误

            iferror !=nil{

                // 参数闭包的调用

                completion("网络服务器错误",false)

                return

            }

            // json数据解析

            let jsonData = try? JSONSerialization.jsonObject(with: data!, options: JSONSerialization.ReadingOptions.allowFragments)

            // json数据解析失败,返回错误

            ifjsonData ==nil{

                completion("网络数据器错误",false)

                return

            }

            letstatus = (jsonDataas!NSDictionary).value(forKey:"status")as!String

            letmsg = (jsonDataas!NSDictionary).value(forKey:"msg")as!String

            ifInt(status)! !=0{

                completion(msg,false)

                return

            }

// 根据网址进行数据解析

//            letresult = (jsonDataas!NSDictionary).value(forKey:"result")as!NSDictionary

  //          letlist = result.value(forKey:"list")as!NSArray

            var newsArr:[NewsModel] = []

            for item in list{

                letdic = itemas!NSDictionary

                letoneNew =NewsModel()

// 根据Model类进行赋值

                oneNew.title= dic.value(forKey:"title")as!String

                newsArr.append(oneNew)

            }

            completion(newsArr,true)

}

        // (6)开启任务

        task.resume()

   }

2、创建模型Model类

在类中定义解析出网址中的字段

例:vartitle:String=""

3、在ViewControll

定义表格,对表格进行赋值,把解析出来的数据赋值给cell

var table:UITableView?

vartableDataArr:[NewsModel]?

创建表格

self.table=UITableView(frame:self.view.frame, style: .plain)

        table?.delegate=self

        table?.dataSource=self

        self.view.addSubview(table!)

// MARK:UITableViewDelegate

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

        ifletcount =tableDataArr?.count{

            returncount

        }

        return0

    }


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

        letidentifier ="cell"

        varcell = tableView.dequeueReusableCell(withIdentifier: identifier)

        ifcell ==nil{

            cell =UITableViewCell(style: .subtitle, reuseIdentifier: identifier)

// cell的内容自动换行

//            cell?.textLabel?.numberOfLines = 0;

//            cell?.detailTextLabel?.numberOfLines = 0;

// 根据模型当中的数据,进行赋值

            letoneNew =self.tableDataArr![indexPath.row]

            cell?.textLabel?.text= oneNew.title

        }

        returncell!

    }

// MARK:请求网络数据

    funcrequestNetWorkDataAndUpdateUI() ->Void{

        // 转动菊花

        UIApplication.shared.isNetworkActivityIndicatorVisible = true

        // 请求网络数据

        leturlService =URLService()

// 调用URLService中的Get方法

        urlService.getNewsData(channel:"头条", startNum:self.startNum) { (data, success) -> (Void)in

            // 先停止指示器

            DispatchQueue.main.async {

                // 停止菊花

                UIApplication.shared.isNetworkActivityIndicatorVisible = false

            }

            // 错误情况,提示

            if!success{

                DispatchQueue.main.async{

                   // 如果网络出错,给用户一个提示

               }

                return

            }

            // 正确情况,加载表格

            // 如果startNum是0,将第一页数据赋值给表格数据

            ifself.startNum==0{

                self.tableDataArr= dataas? [NewsModel]

            }else{  // 如果不是0,将得到的数据拼接到表格数组当中

                letarr = dataas? [NewsModel]

                self.tableDataArr?.append(contentsOf: arr!)


            }

            DispatchQueue.main.async {

// 回到主线程刷新表格

                self.table?.reloadData()

            }

        }

    }

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