Chinaunix首页 | 论坛 | 博客
  • 博客访问: 135013
  • 博文数量: 34
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 700
  • 用 户 组: 普通用户
  • 注册时间: 2014-11-12 16:52
文章分类

全部博文(34)

文章存档

2015年(13)

2014年(21)

我的朋友

分类: iOS平台

2014-12-04 12:21:07

最近在学习ios抓取网页内容时遇到各种重复代码的问题,看着这么多重复的代码,感觉实在不爽,于是学习了iosprotocol

在我看来这个protocol其实应该是Java中的interface

也就是定义一个协议(或者叫接口),定义一堆方法,让实现了该方法的类的实例传入即可。

 

在我的工程中,抓取不同网页的viewcontroller,获取网页的代码完全是一模一样的,除了网址不同以外,别无二致,所以这一部分提取出来作为一个类,专门实现上网取数据,数据取到了需要通知viewcontroller,这时就需要一个回调,这里就用protocol来达到这个目的。

 

先来定义一个protocol

[objc] view plaincopyprint?

1. @objc protocol callBack : NSObjectProtocol {  

2.     func success(data:String)  

3.     optional func error(error: NSError)  

4. }  

 

这里的 protocol就叫 callBack,里面定义了两个方法,其中一个是可选的。

再来定义一个类实现抓取网页

[objc] view plaincopyprint?

1. class NetUtil :NSObject, NSURLConnectionDelegate,NSURLConnectionDataDelegate{  

2.     var cb :callBack?  

3.     init(url:String,cb:callBack) {  

4.         super.init()  

5.         self.cb = cb  

6.         let req : NSURLRequest = NSURLRequest(URL: NSURL(string: url)!)  

7.         let conn : NSURLConnection = NSURLConnection(request: req, delegate: self)!  

8.     }  

9.     var data : NSMutableData!  

10.     var tableData: NSArray = NSArray()  

11.     func connection(connection: NSURLConnection, didReceiveData data: NSData) {  

12.         self.data.appendData(data);  

13.     }  

14.     func connection(connection: NSURLConnection, didReceiveResponse response: NSURLResponse) {  

15.         self.data = NSMutableData();  

16.     }  

17.       

18.     func connectionDidFinishLoading(connection: NSURLConnection) {  

19.         let s = NSString(data: data, encoding: NSUTF8StringEncoding)  

20.         cb?.success(s!)  

21.     }  

22.     func connection(connection: NSURLConnection, didFailWithError error: NSError) {  

23.         cb?.error?(error)  

24.     }  

25. }  

 

我把它叫网络工具吧,由于使用了NSURLConnection来取数据,所以同样这个类需要实现NSURLConnection的两个协议,然后在相应的方法中调用callBack的方法以便通知主程序完成相应的工作。

在成功后调用cb.success(),出错后调用cb.error()

这些都准备好后,再回到相应的viewcontroller中来实现这个callBack协议,并实现调用。

[objc] view plaincopyprint?

1. //  

2. //  ViewController.swift  

3. //  测试工程  

4. //  

5. //  Created by 周蜜 on 14/11/26.  

6. //  Copyright (c) 2014年 

7. //  

8.   

9. import UIKit  

10.   

11. class ViewController: UIViewController,callBack{  

12.   

13.     override func viewDidLoad() {  

14.         super.viewDidLoad()  

15.         var url :String! = ""  

16.         //在这里调用我的网络工具,将self作为实现了协议callBack的参数  

17.         NetUtil(url: url, cb: self)  

18.     }  

19.     @IBOutlet weak var appsTableView: UITableView!  

20.   

21.     override func didReceiveMemoryWarning() {  

22.         super.didReceiveMemoryWarning()  

23.     }  

24.     //这里实现callBack中的必要方法  

25.     func success(data: String) {  

26.         println(data)  

27.     }  

28.       

29. }  


现在看起来我的主程序是不是简单多了?

在对应的success方法中处理取到的数据就可以了。

 

阅读(640) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~