午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

iOS中的MVP模式初探

瀏覽:18日期:2022-09-17 11:04:11

以前在項(xiàng)目中都寫的是MVC模式, 由于現(xiàn)在在項(xiàng)目中要學(xué)習(xí)MVP模式, 所以找了一個(gè)Demo研究了一下. 就簡(jiǎn)單說說自己的看法吧.

先說一下MVC模式, 示意圖如下:

iOS中的MVP模式初探

MVC模式示意圖

模型拿到數(shù)據(jù), 可能是數(shù)據(jù)庫或者網(wǎng)絡(luò)數(shù)據(jù)

最簡(jiǎn)單的比方, 我們拿到一個(gè)模型數(shù)組了之后, 這個(gè)就相當(dāng)于是一個(gè)數(shù)據(jù)源.

將數(shù)據(jù)傳遞給控制器, 控制器經(jīng)過簡(jiǎn)單地加工

數(shù)據(jù)源經(jīng)過簡(jiǎn)單地處理加工, 比如在tableView中, 我們可能會(huì)使用數(shù)據(jù)源方法, 將模型數(shù)組中的元素取出來, 傳遞給View層, 比如cell

將加工后的數(shù)據(jù)展示出來

cell展示模型中的數(shù)據(jù)

那么MVP模式又是怎樣的呢?請(qǐng)看下圖

iOS中的MVP模式初探

MVP模式示意圖

從上圖可以看出, 從MVC中又抽象出了P層, 即Presenter層

Controller其實(shí)將view和viewController傳遞給了P層, 這樣P層其實(shí)就擁有了控制器的權(quán)利, 完全可以行使控制器的職責(zé).

Controller又持有Presenter, 那么它只需要調(diào)用P層暴露出的接口, 就完全可以完成整個(gè)業(yè)務(wù)邏輯和頁面展示

關(guān)于C端和P端的循環(huán)引用的問題, 直接用weak關(guān)鍵字就可以解決了

利用代碼來說明一下問題:

這是一個(gè)Presenter的Protocol, 所有的P層的類都要遵循這個(gè)Protocol

#import /** 作為P : presenter 是管理 view viewController model這個(gè)三個(gè)中間人,負(fù)責(zé)UI刷新 視圖的交互總是和VC 關(guān)聯(lián)著的 */@protocol TGPresenterProtocol @optional// 處理View視圖相關(guān)操作 -- 協(xié)議的遵守者- (void)setView:(NSObject *)view;// 處理事件的相關(guān)響應(yīng)- (void)setViewController:(UIViewController *)viewController;// 展示- (void)present;// 加載model - (void)presentWithModel:(id)model viewController:(UIViewController *)viewController;@end

可以看出, P層是可以拿到view或者viewController的, 并且可以在實(shí)現(xiàn)set方法的時(shí)候做一些事情. 這個(gè)稍后再講

另外, P層還可以展示數(shù)據(jù), 直接展示數(shù)據(jù), present方法, 利用模型展示數(shù)據(jù), 利用presentWithModel:方法

比如, 在一個(gè)遵循了TGPresenterProtocol的Presenter類中

把需要管理的view傳遞給P,

- (instancetype)initWithTableView:(UITableView *)view{self = [super init]; if (!self) {return nil; } _view = view; _view.delegate = self; _view.dataSource = self; _view.separatorStyle = UITableViewCellSeparatorStyleNone; // 自適應(yīng)高度 _view.rowHeight = UITableViewAutomaticDimension; _view.estimatedRowHeight = 100; return self;}- (void)setView:(UITableView *)view{ // 設(shè)置視圖 _view = view; _view.delegate = self; _view.dataSource = self; _view.separatorStyle = UITableViewCellSeparatorStyleNone; // 自適應(yīng)高度 _view.rowHeight = UITableViewAutomaticDimension; _view.estimatedRowHeight = 100;}

比如上面的代碼, 將tableView的數(shù)據(jù)源和代理都給了P, 那么P就相當(dāng)于行使了控制器的權(quán)力, 當(dāng)P層拿到數(shù)據(jù)時(shí)(沒錯(cuò), P層是持有Model的):

- (void)loadHPData{NSString *dataPath = [[NSBundle mainBundle] pathForResource:@'testCellData' ofType:@'json']; NSData *jsonData = [NSData dataWithContentsOfFile:dataPath]; NSError *error; NSDictionary *dataDic = [NSJSONSerialization JSONObjectWithData:jsonData options:NSJSONReadingAllowFragments error:&error]; if (error) {NSLog(@'error = %@',error.localizedDescription); } NSLog(@'dataDic = %@',dataDic); // model 要處理好數(shù)據(jù)的顯示格式 self.hpModel = [[CellSelfSizeModel alloc] initWithDic:dataDic]; // 刷新 [self present]; }

走Present方法, 實(shí)際就是tableView的reloadData:

- (void)present{[self.view reloadData];}

然后重走tableView的數(shù)據(jù)源方法. 將數(shù)據(jù)分發(fā)給cell去展示:

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{return self.hpModel.data.listArray.count;}- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{NSString *ID = @''; cellType type;CelllSelfSizeListModel *newsList; if (indexPath.row > self.hpModel.data.listArray.count - 1) {newsList = nil; }else{newsList = self.hpModel.data.listArray[indexPath.row]; } if (newsList.orginImg.length>0) {// 有圖片type = NewsInListCellTypeHavePic; }else{// 無圖片type = NewsInListCellTypeOnlyWord; }ID = [NSString stringWithFormat:@'reusId%ld',(long)type];SelfSizeTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID]; if (cell == nil) {cell = [[SelfSizeTableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:ID cellType:type]; }cell.cellModel = newsList;return cell;}

這樣就實(shí)現(xiàn)了Controller, View, Model的解耦. 給大家看看控制器做的事情:

- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view.self.title = @'MVP Demo';// 布局 [self initViews]; [self setUpConstraints];self.hpPresenter = [TGHPPresenter new]; // 視圖對(duì)象 self.hpPresenter.view = self.tableView; // 控制器對(duì)象 self.hpPresenter.viewController = self; // 外邊是要傳入?yún)⑦M(jìn)去的 -- 數(shù)據(jù)模型 [self.hpPresenter loadHPData]; }

只需要初始化P層, 然后調(diào)P層的接口就可以了. 至于P層內(nèi)部的邏輯, 我不需要知道

V層也只專注于視圖的創(chuàng)建

M層只專注于模型的構(gòu)建(字典->模型)

這樣分層, 解耦的思想在程序設(shè)計(jì)中是極為重要的. 其實(shí)也可以看出MVP是對(duì)MVC模式的進(jìn)一步抽象.

代碼Demo是我們老大寫的, 我只是分析了一波

來自:http://www.cocoachina.com/ios/20171106/21062.html

標(biāo)簽: IOS
相關(guān)文章:
主站蜘蛛池模板: 国产一区二区免费看 | 久久久久久一级片 | 国产视频在线一区 | 欧美黄色一级视频 | 在线不欧美 | 国产视频一区二区在线观看 | 午夜天堂在线 | 国产一级淫片a | 95看片淫黄大片一级 | 精品国产一区二区三区久久久蜜臀 | 亚洲a网站 | 国产无遮挡又黄又爽免费网站 | 欧美激情在线播放 | 在线观看亚洲网站 | 成年人免费看毛片 | 免费的黄色av | 少妇视频一区 | 国产在线导航 | 第一页av| 成人激情视频在线播放 | 五月视频 | 亚洲视频播放 | 精品视频一区二区三区 | 国产99精品视频 | 九九热国产精品视频 | 国产激情福利 | 久久经典 | 国产成人精品视频 | 日本免费一区二区三区四区 | 亚州欧美日韩 | 岛国av免费在线观看 | 中文字幕一区二区在线播放 | 国产精品福利视频 | 日韩免费视频网站 | 亚洲情侣在线 | 国内精品999 | 成人福利视频在线观看 | 日韩www视频| 日韩第一视频 | 久久久久逼 | www.亚洲成人 |