最后的gif效果圖
一款移動(dòng)應(yīng)用一旦需要后端服務(wù)的強(qiáng)大支撐時(shí),開發(fā)商就必須考慮基礎(chǔ)架構(gòu)壶硅、服務(wù)集成腊凶、可伸縮性等繁冗復(fù)雜的問題编矾。而在這些方面耗費(fèi)的大量時(shí)間精力財(cái)力卻不能直接提升App的用戶體驗(yàn)。
為了解決這些問題箱熬,部分App發(fā)行商租用了譬如AWS(Amazon Web Services)的公有云服務(wù)类垦,有的則部署內(nèi)部專用的私有云服務(wù)。而移動(dòng)開發(fā)團(tuán)隊(duì)越來越趨向于小規(guī)某切耄化蚤认,架設(shè)需要高成本運(yùn)營的服務(wù)器群或許并不是最好的方法,租用或免費(fèi)使用后端云服務(wù)開始流行起來糕伐。
這里我們演示一下國內(nèi)使用率最多的Bmob云來進(jìn)行學(xué)習(xí)砰琢。
注冊(cè)賬號(hào)并創(chuàng)建應(yīng)用的過程略過,如果你已經(jīng)看到這里的話應(yīng)該至少算是個(gè)程序員了,不可能不會(huì)的陪汽。然后我們?cè)趐od中添加bmob:
pod 'BmobSDK', '~> 1.6.5'
然后記得更新一下 pod update
接著我們將學(xué)習(xí)如何在Swift中調(diào)用Objective-C的SDK:
創(chuàng)建一個(gè)Objective-C 文件训唱,new File > iOS > Source > Objective-C File,隨便命名一個(gè)保存即可
然后創(chuàng)建挚冤,一定要選擇Create Bridging Header
完成后看到項(xiàng)目中多了兩個(gè)文件
刪除剛剛創(chuàng)建的.m文件况增,并在自動(dòng)生成的.h文件中添加BmobSDK的引用
#import <BmobSDK/Bmob.h>
保存后我們就可以在其它地方調(diào)用BmobSDK了,添加別的Objective-C第三方庫也是一樣的操作训挡,生成Bridging-Header.h文件后在其中import即可澳骤。
然后我們開始使用Bmob來展示App數(shù)據(jù)。
首先在AppDelegate的didFinishLaunchingWithOptions中注冊(cè)Bmob:
Bmob.registerWithAppKey("Application ID")
然后就可以調(diào)用Bmob的增刪改查啦澜薄,MainViewController中測(cè)試一個(gè)創(chuàng)建表的操作:
//創(chuàng)建方法
func saveObj(){
var obj:BmobObject = BmobObject(className: "GameScore")
obj.setObject(3, forKey: "class")
obj.saveInBackground()
}
我們調(diào)用一下這個(gè)方法并run一下宴凉,之后到Bmob后臺(tái)查看,
我調(diào)用了兩次表悬,已經(jīng)成功的創(chuàng)建了一張名為GameScore的表弥锄,并且保存了兩條數(shù)據(jù)了,說明我們操作是成功的蟆沫。
然后我們直接在頁面上新建一個(gè)DoctorUser的表籽暇,并添加三個(gè)醫(yī)生的數(shù)據(jù)測(cè)試一下:
接著我們更換tableView為真實(shí)數(shù)據(jù)
var list:NSMutableArray = NSMutableArray()
numberOfRowsInSection修改為list.count
override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return list.count
}
再修改之前的上下拉方法
/**
下拉刷新
*/
func downPlullLoadData(){
xwDelay(1) { () -> Void in //延遲一秒再查詢
let query:BmobQuery = BmobQuery(className:"DoctorUser")
query.cachePolicy = kBmobCachePolicyNetworkElseCache // 優(yōu)先使用Bmob本地緩存
query.findObjectsInBackgroundWithBlock({array,error in
self.list.removeAllObjects() //先將之前的數(shù)據(jù)清除
for var obj in array {
self.list.addObject(obj) //再循環(huán)添加
}
self.tableView.reloadData()
self.tableView.headerView?.endRefreshing() //刷新結(jié)束
}
)
}
}
/**
上拉加載更多
*/
func upPullLoadData(){
xwDelay(1) { () -> Void in
let query:BmobQuery = BmobQuery(className:"DoctorUser")
query.cachePolicy = kBmobCachePolicyNetworkElseCache
query.findObjectsInBackgroundWithBlock({array,error in
for var obj in array {
self.list.addObject(obj) //加載更多時(shí)直接添加數(shù)據(jù)
}
self.tableView.reloadData()
self.tableView.footerView?.endRefreshing()
}
)
}
}
現(xiàn)在我們運(yùn)行一下,可以看到數(shù)量查出來是正確的饭庞,上拉加載更多時(shí)因?yàn)槲覀儍H僅只有3條測(cè)試數(shù)據(jù)戒悠,所以不用增加偏移量,始終從0開始查就可以了舟山。
現(xiàn)在我們來修改cellForRowAtIndexPath方法绸狐,類似android中的getView
override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("cell", forIndexPath: indexPath) as! DoctorCell
let doctor = list[indexPath.row] as! BmobObject
cell.lblName.text = doctor.objectForKey("name") as? String
cell.lblPosition.text = doctor.objectForKey("position") as? String
cell.lblHospital.text = "\(doctor.objectForKey("hospital")) \(doctor.objectForKey("department"))"
cell.lblGood.text = doctor.objectForKey("good") as? String
return cell
}
我們需要一個(gè)圖片加載的第三方庫,在Pod中添加pod 'Kingfisher', '~> 1.8'
并update
完成后import Kingfisher累盗,再到cellForRowAtIndexPath中添加一行對(duì)ivHead的修改
cell.ivHead.kf_setImageWithURL(NSURL(string: doctor.objectForKey("head") as! String)!)
再次運(yùn)行寒矿,數(shù)據(jù)已經(jīng)很完美的展示到界面上了:
ok ,第6節(jié)結(jié)束若债,大家可以多找一些別的第三方SDK集成實(shí)驗(yàn)符相,現(xiàn)在的互聯(lián)網(wǎng)就是一堆堆的輪子,大家要么造輪子蠢琳,要么用輪子啊终,很多好用的第三方已經(jīng)給我們寫好了,我們直接使用api就行傲须,既然是這樣蓝牲,在滿足需求的前提下,我當(dāng)然是直接用輪子泰讽,讓更多的精力放到編程的思想上去例衍,不然我一個(gè)母語是C#的androider來學(xué)iOS的Swift怎么可能快起來呢散怖?