扯兩句MVC的設(shè)計(jì)模式

純手打.png

一個(gè)app開(kāi)發(fā)的主要流程可以簡(jiǎn)單概括為:
搭建UI界面---> 請(qǐng)求服務(wù)器數(shù)據(jù) ---> 把數(shù)據(jù)展示在UI界面上 --> 處理UI界面的業(yè)務(wù)邏輯 ---> 測(cè)試及優(yōu)化

在編程世界里面大家都知道一句話: 高內(nèi)聚,低耦合

  • 高內(nèi)聚,就是指盡量讓一個(gè)類(lèi)或者一個(gè)方法它專(zhuān)門(mén)去處理一個(gè)事情,對(duì)外只提供一個(gè)接口,內(nèi)部具體如何實(shí)現(xiàn)不需要告訴外界.
  • 低耦合,就是減少類(lèi)與類(lèi)之間相互的依賴(lài)性,降低代碼的入侵性,當(dāng)改變一個(gè)類(lèi)中的一個(gè)東西時(shí)候,不需要另一個(gè)類(lèi)中也大批量改.

我們?cè)谡?qǐng)求網(wǎng)絡(luò)數(shù)據(jù)的時(shí)候,通常服務(wù)器給我們返回都是json或者xml數(shù)據(jù),我們利用第三方框架將它解析之后會(huì)得到一個(gè)字典數(shù)組.
這時(shí)候如果我們面向字典來(lái)開(kāi)發(fā):
1.這樣不太符合我們面向?qū)ο?/strong>開(kāi)發(fā)的偉大思想覺(jué)悟
2.由于xcode的原因,在敲字典的key時(shí)候系統(tǒng)是不會(huì)給我們提示(也就是自動(dòng)聯(lián)想功能)的,這樣容易造成我們有時(shí)候不小心敲錯(cuò)了一個(gè)key導(dǎo)致加載不出數(shù)據(jù),但是系統(tǒng)又不會(huì)報(bào)錯(cuò),代碼一多很可能就要花很多時(shí)間去找八哥(bug),專(zhuān)業(yè)點(diǎn)來(lái)講就是容錯(cuò)率低.

所以為了順應(yīng)社會(huì)主義發(fā)展的步伐,我們需要將字典數(shù)組轉(zhuǎn)換為模型數(shù)組,也就是將字典轉(zhuǎn)為模型, 這就要扯到MVC這個(gè)設(shè)計(jì)模式了.

MVC是三個(gè)單詞的首字母縮寫(xiě), 他們分別是 , 他們分別是, 分別是Model, View, Controller, 也就是模型, 視圖, 控制器.

  • Model : 繼承NSObject, 負(fù)責(zé)保存數(shù)據(jù).
  • View : 視圖控件, 通常用xib來(lái)描述它里面的子控件,負(fù)責(zé)將數(shù)據(jù)展示在UI界面上
  • Controller : 控制器,負(fù)責(zé)請(qǐng)求及處理網(wǎng)絡(luò)數(shù)據(jù), 處理用戶(hù)交互

他們?nèi)值艿年P(guān)系如下:

圖片來(lái)自網(wǎng)絡(luò).png

這樣子,他們?nèi)齻€(gè)各司其職, 符合我們高內(nèi)聚,低耦合的思想.

下面用簡(jiǎn)單的table view實(shí)例來(lái)闡述一下MVC的使用,如下圖的效果

table view.png

誰(shuí)能教教我用markdown放入圖片怎么設(shè)置圖片大小?


66666.png

1.在Model(也叫Item)里面定義屬性,用來(lái)保存網(wǎng)絡(luò)數(shù)據(jù)

#import <Foundation/Foundation.h>

@interface tagItem : NSObject

@property(nonatomic,strong)NSString *image_list;
@property(nonatomic,strong)NSString *sub_number;
@property(nonatomic,strong)NSString *theme_name;

@end

2.在Controller里面,請(qǐng)求數(shù)據(jù),用第三方框架把數(shù)據(jù)轉(zhuǎn)化成模型存進(jìn)Model這個(gè)類(lèi)中, 然后給cell的item屬性賦值,這樣子就可以把item(數(shù)據(jù))傳進(jìn)View里面------簡(jiǎn)單的說(shuō),就是在Controller里面把數(shù)據(jù)傳進(jìn)View里面

//發(fā)送網(wǎng)絡(luò)請(qǐng)求
-(void)loadData
{
    
    AFHTTPSessionManager *mgr = [AFHTTPSessionManager ljw_manager];
    
    NSMutableDictionary *parameters = [NSMutableDictionary dictionary];
    parameters[@"a"] = @"tag_recommend";
    parameters[@"action"] = @"sub";
    parameters[@"c"] = @"topic";
    self.mgr = mgr;
    
    [mgr GET:@"http://api.budejie.com/api/api_open.php" parameters:parameters progress:nil success:^(NSURLSessionDataTask * _Nonnull task, NSDictionary *  _Nullable responseObject) {
        //字典數(shù)組轉(zhuǎn)模型數(shù)組
        _tags = [tagItem mj_objectArrayWithKeyValuesArray:responseObject];

        [self.tableView reloadData];
        [SVProgressHUD dismiss];
    
    } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
        NSLog(@"%@",error);
        [SVProgressHUD dismiss];

    }];

}
#pragma mark - Table view data source
//設(shè)置cell的高度
-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{

    return 60 + 10;
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {

    return _tags.count;
}

-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    LJWAllTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
    tagItem *item = _tags[indexPath.row];
    
    //把數(shù)據(jù)傳給cell
    cell.item = item;
    
    return  cell;
}

3.在View里面描述好xib,
然后定義item這個(gè)屬性,并把各子控件拖好線,
重寫(xiě)item這個(gè)屬性的getter方法(因?yàn)樵诳刂破髦薪oitem屬性賦值時(shí)候就會(huì)調(diào)用這個(gè)方法), 在這個(gè)setter方法中用這個(gè)item的各個(gè)屬性來(lái)給View的子控件賦值, 達(dá)到把數(shù)據(jù)展示在UI界面上的目的---簡(jiǎn)單來(lái)說(shuō)就是在View里面拿到Model數(shù)據(jù),把數(shù)據(jù)展示在View上

#import "LJWAllTableViewCell.h"
#import "tagItem.h"

@interface LJWAllTableViewCell()

@property (weak, nonatomic) IBOutlet UILabel *nameLabel;
@property (weak, nonatomic) IBOutlet UILabel *numberLabel;
@property (weak, nonatomic) IBOutlet UIImageView *imageV;

@end

-(void)setItem:(tagItem *)item
{
    _item = item;
    
    //名字*********************
    _nameLabel.text = item.theme_name;

    
    //訂閱數(shù)******************
    NSString *numStr = [NSString stringWithFormat:@"%@人訂閱",_item.theme_name];
    CGFloat num = [_item.sub_number floatValue];
    if (num > 10000) {
        num = num / 10000;
        numStr = [NSString stringWithFormat:@"%.1f人訂閱",num];
    }
    _numberLabel.text = numStr;
    
    //圖片 ********************
    [_imageV sd_setImageWithURL:[NSURL URLWithString:_item.image_list] placeholderImage:[UIImage imageNamed:@"defaultUserIcon"] completed:^(UIImage * _Nullable image, NSError * _Nullable error, SDImageCacheType cacheType, NSURL * _Nullable imageURL) {
        //生成圓形圖片
       
        //開(kāi)啟上下文
        UIGraphicsBeginImageContextWithOptions(image.size, NO, 0);
        
        //描述裁剪路徑
        UIBezierPath *path = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0, 0, image.size.width, image.size.height)];
        
        //設(shè)置裁剪區(qū)域
        [path addClip];
        
        //開(kāi)始裁剪
        [image drawAtPoint:CGPointZero];
        
        //獲取裁剪后的圖片
        image = UIGraphicsGetImageFromCurrentImageContext();
        
        //關(guān)閉上下文
        UIGraphicsEndImageContext();
        
        _imageV.image = image;

    }];

大致思路就是這樣, 還有一些細(xì)節(jié)的業(yè)務(wù)邏輯之類(lèi)的根據(jù)實(shí)際需要處理好就行.

用MVC在日后可以方便地對(duì)代碼進(jìn)行維護(hù), 可以達(dá)到"哪里出問(wèn)題,就去找對(duì)應(yīng)的類(lèi)修改"的效果.

下一篇將寫(xiě)MVVM的設(shè)計(jì)模式.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末才避,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌区匠,老刑警劉巖草讶,帶你破解...
    沈念sama閱讀 218,525評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件表蝙,死亡現(xiàn)場(chǎng)離奇詭異蒲讯,居然都是意外死亡宰掉,警方通過(guò)查閱死者的電腦和手機(jī)蕴侧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)择同,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人净宵,你說(shuō)我怎么就攤上這事敲才」桑” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,862評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵紧武,是天一觀的道長(zhǎng)剃氧。 經(jīng)常有香客問(wèn)我,道長(zhǎng)阻星,這世上最難降的妖魔是什么朋鞍? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,728評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮妥箕,結(jié)果婚禮上滥酥,老公的妹妹穿的比我還像新娘。我一直安慰自己矾踱,他們只是感情好恨狈,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,743評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著呛讲,像睡著了一般禾怠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上贝搁,一...
    開(kāi)封第一講書(shū)人閱讀 51,590評(píng)論 1 305
  • 那天吗氏,我揣著相機(jī)與錄音,去河邊找鬼雷逆。 笑死弦讽,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的膀哲。 我是一名探鬼主播往产,決...
    沈念sama閱讀 40,330評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼某宪!你這毒婦竟也來(lái)了仿村?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,244評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤兴喂,失蹤者是張志新(化名)和其女友劉穎蔼囊,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體衣迷,經(jīng)...
    沈念sama閱讀 45,693評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡畏鼓,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,885評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了壶谒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片云矫。...
    茶點(diǎn)故事閱讀 40,001評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖汗菜,靈堂內(nèi)的尸體忽然破棺而出让禀,到底是詐尸還是另有隱情贵少,我是刑警寧澤,帶...
    沈念sama閱讀 35,723評(píng)論 5 346
  • 正文 年R本政府宣布堆缘,位于F島的核電站,受9級(jí)特大地震影響普碎,放射性物質(zhì)發(fā)生泄漏吼肥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,343評(píng)論 3 330
  • 文/蒙蒙 一麻车、第九天 我趴在偏房一處隱蔽的房頂上張望缀皱。 院中可真熱鬧,春花似錦动猬、人聲如沸啤斗。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,919評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)钮莲。三九已至,卻和暖如春彼水,著一層夾襖步出監(jiān)牢的瞬間崔拥,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,042評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工凤覆, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留链瓦,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,191評(píng)論 3 370
  • 正文 我出身青樓盯桦,卻偏偏與公主長(zhǎng)得像慈俯,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子拥峦,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,955評(píng)論 2 355

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