Swift - 提取UILabel、UIButton,隔离网络层

1.提取UILabel
##用闭包的形式把相关参数传入,返回值类型UILabel
闭包写法:函数名(相关属性参数) -> 返回值类型 {}
##eg:
extension UILabel{
    /// - Parameters:
    ///   - text: <#text description#>
    ///   - textColor: <#textColor description#>
    ///   - fontSize: <#fontSize description#>
    ///   - numberlines: <#numberlines description#>
    /// - Returns: <#return value description#>
    class func create(text:String?,textColor:UIColor = .lightGray,fontSize:CGFloat = 12,numberlines:Int = 1) -> UILabel{
        
        let label = UILabel()
        label.text = text
        label.textColor = textColor
        label.font = UIFont.systemFont(ofSize: fontSize)
        label.numberOfLines = numberlines
        label.sizeToFit()
    
        return label
    }
}

##UIButton:
extension UIButton {
    class func yt_CreateButton(image:UIImage?, title:String?, titleColor: UIColor = .black, fontSize:CGFloat = 12.0) -> UIButton {
        let button = UIButton()
        button.setImage(image, for: .normal)
        button.setTitle(title, for: .normal)
        button.setTitleColor(titleColor, for: .normal)
        button.titleLabel?.font = UIFont.systemFont(ofSize: fontSize)
        return button
    }
}
2.隔离网络层
我们用到的是Alamofire,Alamofire就是swift版本的AFNetworking
###为什么要隔离网络层?
举个例子来说,加入现在项目中要换掉现在使用的请求网络的方法,而我们没有以前使用的时候把这些请求数据的
代码散落在项目中的个个地方,那我们现在替换的时候花的时间和精力就会特别多~~而且还有可能导致各种错误;
但是我们隔离好网络层后,我们只需在这个工具类里面替换方法,外面调用这个方法的类甚至都不需要修改,大大
提高了效率,减少了错误发生的几率
###下面附上代码
class AlamofireManager{
    
    static let shared = AlamofireManager()
    
    
   /// 返回值为字典的请求方式
    ///
    /// - Parameters:
    ///   - url: 请求地址
    ///   - method: GET / POST
    ///   - parameters: 请求参数,字典,可选
    ///   - finnish: 回调(json:网络请求回来的数据,isSuccess:是否有请求数据,有则回调)
    func loadDic(url:String,method:YHTTPMethod,parameters: [String:AnyObject]?,finnish:@escaping (_ json:[String:AnyObject]?, _ isSuccess:Bool)->()) {
        
        let gp = (method == YHTTPMethod.GET) ? HTTPMethod.get : HTTPMethod.post
        
        Alamofire.request(url, method: gp, parameters: parameters, encoding: JSONEncoding.default, headers: nil).responseJSON { (response) in
            print(response.result.value ?? 1)
            
            guard let result = response.result.value as? [String:AnyObject] else{
                finnish(nil ,false)
                return
            }
            
            finnish(result,true)
        }
    }
    
    /// 返回值为数组的请求方式
    ///
    /// - Parameters:
    ///   - url: 请求地址
    ///   - method: GET / POST
    ///   - parameters: 请求参数,字典,可选
    ///   - finnish: 回调(json:网络请求回来的数据,数组类型,isSuccess:是否有请求数据,有则回调)
    func loadArr(url:String,method:HTTPMethod,parameters: [String:AnyObject]?,finnish:@escaping (_ json:[AnyObject]?, _ isSuccess:Bool)->()) {
        
        
        Alamofire.request(url, method: method, parameters: parameters, encoding: JSONEncoding.default, headers: nil).responseJSON { (response) in
//            print(response.result.value ?? 1)
            // 数组的方法
            guard let result = response.result.value as? [AnyObject] else{
                finnish(nil ,false)
                
                return
            }
            
            finnish(result,true)
        }
    }
    
    fileprivate init(){} // 禁用掉init,只让调用单例方法

}
3.调用隔离好的网络层
创建一个ViewModel,写上方便外面调用数据的方法,并创建一个数组,将所有的数据写成模型放在数组中,下面附上代码
class ViewModel {
    
    
    var array = [Model]()
    
    /// 请求方法
    ///
    /// - Parameter complete: 闭包回调,通知通知控制器数据已准备完成
    func loadData(complete:@escaping (_ finish:Bool)->()) {
        
        /// 请求参数
//        NetworkingManager.shared.request(URLString: <#T##String#>, parameter: <#T##[String : AnyObject]?#>, finish: <#T##(AnyObject?, Bool) -> ()#>)
        
        let parames = ["XXX": "XXX",
                       "XXX": "XXX",
                       "XXX":XXX] as [String : AnyObject]
        
        AlamofireManager.shared.loadDic(url: "XXX", method: .POST, parameters: parames ) { (json, isSuccess) in
            if isSuccess {
                
                
//                guard let data = try? JSONSerialization.data(withJSONObject: json ?? "", options: [.prettyPrinted]) else{
//                    complete(false)
//                    return
//                }
//
//                (data as NSData).write(toFile: "/Users/wu/Desktop/index.json", atomically: true)
                guard let result = json?["data"] as? [[String:AnyObject]] else{
                    complete(false)
                    return
                }
                for dic in result{
                    self.array.append(Model(dic: dic))
                }
                complete(true)
            }else{
                complete(false)
            }
        }       
    }
}
###下面这段代码,只是为了把网络数据写入本地,例如桌面上,方便查看数据源的数据
     guard let data = try? JSONSerialization.data(withJSONObject: json ?? "", options: [.prettyPrinted]) else{
        complete(false)
        return
     }
     (data as NSData).write(toFile: "XXX.json", atomically: true)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342

推荐阅读更多精彩内容