6.IOS(swift)-scrollView(tableView) ·下拉刷新上拉加載

上一次我們實現(xiàn)了緩存圖片加載,這一次我們在上次的基礎(chǔ)上加上下拉刷新,上拉加載。


Paste_Image.png

申明var data:NSArray = NSArray(),作為獲取數(shù)據(jù)的儲存,網(wǎng)絡(luò)數(shù)據(jù)獲取到后都放入data.下面創(chuàng)建下拉刷新和上拉加載婴氮。

 var refreshing: Bool = false {
        didSet {
            if (self.refreshing) {
                self.refreshControl?.beginRefreshing()
                self.refreshControl?.attributedTitle = NSAttributedString(string: "Loading...")
                println("Loading...")
            }
            else {
                
                self.refreshControl?.endRefreshing()
                self.refreshControl?.attributedTitle = NSAttributedString(string: "Pull to Refresh")
                println("Loaded & set:Pull to Refresh")
            }
        }
    }

override func viewDidLoad() {
        super.viewDidLoad()
        //添加下拉刷新
        self.refreshControl = UIRefreshControl()
        self.refreshControl?.addTarget(self, action: "onPullToFresh", forControlEvents: UIControlEvents.ValueChanged)
        self.tableView.addSubview(refreshControl!)
        //上拉刷新
        self.setupInfiniteScrollingView()
    
    }
//下拉獲取數(shù)據(jù)
func onPullToFresh() {
        
        fetchDataFromServer()        
}

//上拉刷新
 private func setupInfiniteScrollingView() {
        self.infiniteScrollingView = UIView(frame: CGRectMake(0, self.tableView.contentSize.height, self.tableView.bounds.size.width, 60))
        self.infiniteScrollingView!.autoresizingMask = UIViewAutoresizing.FlexibleWidth
        self.infiniteScrollingView!.backgroundColor = UIColor.whiteColor()
        var activityViewIndicator = UIActivityIndicatorView(activityIndicatorStyle: UIActivityIndicatorViewStyle.White)
        activityViewIndicator.color = UIColor.darkGrayColor()
        activityViewIndicator.frame = CGRectMake(self.infiniteScrollingView!.frame.size.width/2-activityViewIndicator.frame.width/2, self.infiniteScrollingView!.frame.size.height/2-activityViewIndicator.frame.height/2, activityViewIndicator.frame.width, activityViewIndicator.frame.height)
        activityViewIndicator.startAnimating()
        self.infiniteScrollingView!.addSubview(activityViewIndicator)
    }

實現(xiàn)上拉加載的原理:
1.cellForRowAtIndexPath 中判斷下拉位置,執(zhí)行加載操作
2.第一次申請的數(shù)據(jù)(數(shù)組)放入data
3.第二次以后申請的數(shù)據(jù)使用arrayByAddingObjectsFromArray往data填充盾致,更新tableView

 func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as! TableViewCell
        //當(dāng)下拉到底部主经,執(zhí)行l(wèi)oadMore()
        if (loadMoreEnabled && indexPath.row == self.data.count-1) {
            self.tableView.tableFooterView = self.infiniteScrollingView
            loadMore()
        }
        return cell
}

func loadMore(){
        println("loadMore")
        self.data = self.data.arrayByAddingObjectsFromArray(self.newData as! [String])
        self.tableView.reloadData()
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市庭惜,隨后出現(xiàn)的幾起案子罩驻,更是在濱河造成了極大的恐慌,老刑警劉巖蜈块,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鉴腻,死亡現(xiàn)場離奇詭異,居然都是意外死亡百揭,警方通過查閱死者的電腦和手機(jī)爽哎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來器一,“玉大人课锌,你說我怎么就攤上這事。” “怎么了渺贤?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵雏胃,是天一觀的道長。 經(jīng)常有香客問我志鞍,道長瞭亮,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任固棚,我火速辦了婚禮统翩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘此洲。我一直安慰自己厂汗,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布呜师。 她就那樣靜靜地躺著娶桦,像睡著了一般。 火紅的嫁衣襯著肌膚如雪汁汗。 梳的紋絲不亂的頭發(fā)上衷畦,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天,我揣著相機(jī)與錄音碰酝,去河邊找鬼霎匈。 笑死,一個胖子當(dāng)著我的面吹牛送爸,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播暖释,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼袭厂,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了球匕?” 一聲冷哼從身側(cè)響起纹磺,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎亮曹,沒想到半個月后橄杨,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡照卦,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年式矫,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片役耕。...
    茶點故事閱讀 38,789評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡采转,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出瞬痘,到底是詐尸還是另有隱情故慈,我是刑警寧澤板熊,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站察绷,受9級特大地震影響干签,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜拆撼,卻給世界環(huán)境...
    茶點故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一筒严、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧情萤,春花似錦鸭蛙、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至睁宰,卻和暖如春肪获,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背柒傻。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工孝赫, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人红符。 一個月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓青柄,卻偏偏與公主長得像,于是被迫代替她去往敵國和親预侯。 傳聞我的和親對象是個殘疾皇子致开,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,697評論 2 351

推薦閱讀更多精彩內(nèi)容