閉包:掌廚 ? 實例一 ,閉包的 聲明與使用

閉包的 聲明與使用

閉包: 實例一 ,閉包 + 屬性

一個視圖控制器 上面 有 一個 scrollView, 滾動視圖 包含 三個界面翰舌。

三個界面 都是 表視圖, 第一個界面 的 第一個 cell 是 滾動視圖冬骚,CBRecommendADCell

點擊 第一個界面 的 每一副 圖片灶芝, 都有一個 新的 視圖控制器郑原。

class CBRecommendADCell: UITableViewCell , 這個是 最上層


class CBRecommendADCell: UITableViewCell {
    
    //public typealias CBCellClosure = (String?, String) -> Void
    //MARK:-  這個好   A

    //圖片的點擊事件
    var clickClosure: ((String?, String) -> Void)?
    //              2   A     聲明
    
    @IBOutlet weak var scrollView: UIScrollView!

    @IBOutlet weak var pageCtrl: UIPageControl!
    
    
    //數(shù)據(jù)
    var bannerArray: Array<CBRecommendBannerModel>? {
        
        didSet {
            //顯示UI
            showData()
            
        }
        
    }
    
    
    func showData(){
        
        //刪除之前的子視圖
        for sub in scrollView.subviews {
            sub.removeFromSuperview()
        }
        
        
        let cnt = bannerArray?.count
        if cnt > 0 {
            
            //0.添加一個容器視圖
            let containerView = UIView.createView()
            scrollView.addSubview(containerView)
            //設置約束
            containerView.snp_makeConstraints(closure: {
                [weak self]
                (make) in
                make.edges.equalTo(self!.scrollView)
                make.height.equalTo(self!.scrollView)
            })
            
            
            
            var lastView: UIView? = nil
            for i in 0..<cnt! {
                
                //1.獲取模型對象
                let model = bannerArray![i]
                
                //2.創(chuàng)建圖片
                let tmpImageView = UIImageView.createImageView(nil)
                //在線加載圖片
                /*
                 第一個參數(shù):圖片網(wǎng)址的url
                 第二個參數(shù):默認圖片
                 第三個參數(shù):選項
                 第四個參數(shù):可以獲取下載的進度
                 第五個參數(shù):下載結束的時候的操作
                 */
                
                let url = NSURL(string: model.banner_picture!)
                let image = UIImage(named: "sdefaultImage")
                tmpImageView.kf_setImageWithURL(url, placeholderImage: image, optionsInfo: nil, progressBlock: nil, completionHandler: nil)
                containerView.addSubview(tmpImageView)
                
                //添加手勢
                tmpImageView.userInteractionEnabled = true
                tmpImageView.tag = 500+i
                let g = UITapGestureRecognizer(target: self, action: #selector(tapImage(_:)))
                tmpImageView.addGestureRecognizer(g)
                
                //約束
                tmpImageView.snp_makeConstraints(closure: { (make) in
                    make.top.bottom.equalTo(containerView)
                    make.width.equalTo(kScreenWidth)
                    if i == 0 {
                        make.left.equalTo(containerView)
                    }else{
                        make.left.equalTo((lastView?.snp_right)!)
                    }
                })
                
                lastView = tmpImageView
                
            }
            
            //修改容器視圖的約束
            containerView.snp_makeConstraints(closure: { (make) in
                make.right.equalTo((lastView?.snp_right)!)
            })
            
            
            //修改分頁控件
            pageCtrl.numberOfPages = cnt!
            
            //設置代理
            scrollView.delegate = self
            scrollView.pagingEnabled = true
            
        }
       
        
    }
    
    
    func tapImage(g: UIGestureRecognizer) {
        let index = (g.view?.tag)!-500
        
        //獲取模型對象
        let imageModel = bannerArray![index]
        //MARK: -  B         閉包的  使用
        //要將點擊事件傳到視圖控制器
        clickClosure!(nil, imageModel.banner_link!)
    }
    
    
    //創(chuàng)建cell的方法
    /*
     @param tableView:cell所在的表格
     @param indexPath:cell在表格上的位置
     @param model:cell顯示的數(shù)據(jù)
     @param cellClosure:圖片點擊事件
     */
    
    
    //MARK:-  很好
    
    class func createAdCellFor(tableView: UITableView, atIndexPath indexPath: NSIndexPath, withModel model: CBRecommendModel,cellClosure: ((String?, String) -> Void)?) -> CBRecommendADCell {
        //  3     public typealias CBCellClosure = (String?, String) -> Void
        let cellId = "recommendADCellId"
        
        var cell = tableView.dequeueReusableCellWithIdentifier(cellId) as? CBRecommendADCell
        if nil == cell {
            cell = NSBundle.mainBundle().loadNibNamed("CBRecommendADCell", owner: nil, options: nil).last as? CBRecommendADCell
        }
        
        //顯示數(shù)據(jù)
        cell?.bannerArray = model.data?.banner
        
        //點擊事件
        //MARK: -   5   C    閉包 的 傳遞
        cell?.clickClosure = cellClosure
        
        return cell!
    }
    
    
    override func awakeFromNib() {
        super.awakeFromNib()
        // Initialization code
    }

    override func setSelected(selected: Bool, animated: Bool) {
        super.setSelected(selected, animated: animated)

        // Configure the view for the selected state
    }
    
}

//MARK: UIScrollView代理
extension CBRecommendADCell: UIScrollViewDelegate {
    
    func scrollViewDidEndDecelerating(scrollView: UIScrollView) {
        
        let index = Int(scrollView.contentOffset.x/scrollView.bounds.size.width)
        pageCtrl.currentPage = index
        
    }
    
}



最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末夜涕,一起剝皮案震驚了整個濱河市犯犁,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌女器,老刑警劉巖酸役,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異驾胆,居然都是意外死亡涣澡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進店門丧诺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來入桂,“玉大人,你說我怎么就攤上這事驳阎】钩睿” “怎么了?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵呵晚,是天一觀的道長蜘腌。 經(jīng)常有香客問我,道長饵隙,這世上最難降的妖魔是什么撮珠? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮金矛,結果婚禮上芯急,老公的妹妹穿的比我還像新娘。我一直安慰自己驶俊,他們只是感情好志于,可當我...
    茶點故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著废睦,像睡著了一般伺绽。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上嗜湃,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天奈应,我揣著相機與錄音,去河邊找鬼购披。 笑死杖挣,一個胖子當著我的面吹牛,可吹牛的內容都是我干的刚陡。 我是一名探鬼主播惩妇,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼株汉,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了歌殃?” 一聲冷哼從身側響起乔妈,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎氓皱,沒想到半個月后路召,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡波材,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年股淡,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片廷区。...
    茶點故事閱讀 40,090評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡唯灵,死狀恐怖,靈堂內的尸體忽然破棺而出隙轻,到底是詐尸還是另有隱情埠帕,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布大脉,位于F島的核電站搞监,受9級特大地震影響水孩,放射性物質發(fā)生泄漏镰矿。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一俘种、第九天 我趴在偏房一處隱蔽的房頂上張望秤标。 院中可真熱鬧,春花似錦宙刘、人聲如沸苍姜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽衙猪。三九已至,卻和暖如春布近,著一層夾襖步出監(jiān)牢的瞬間垫释,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工撑瞧, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留棵譬,地道東北人。 一個月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓预伺,卻偏偏與公主長得像订咸,于是被迫代替她去往敵國和親曼尊。 傳聞我的和親對象是個殘疾皇子脏嚷,可洞房花燭夜當晚...
    茶點故事閱讀 45,033評論 2 355

推薦閱讀更多精彩內容