(IOS)關于MVVM見解與實踐

在此之前,我在網上看了很多關于MVVM的文章,其中MVVM+RAC的模式最多,我想說的是MVVM和RAC沒有必然的關系,也不是說MVVM只要結合RAC就會變得更加簡單。之所以MVVM會用到RAC,不過是在一些特殊場景下,比如利用RAC的雙向綁定特性,更容易實現某些功能,而MVVM的大部分場景是不需要RAC的,用block就能輕而易舉的實現大部分場景的功能。

在我看來很多人把本來簡單的MVVM復雜化使用了。并沒有抓住MVVM的核心。下面我簡單明了從一下幾點對MVVM進行刨析。

1.MVVM會為Controller瘦身的,如果你用了MVVM,而你的C還是那么胖,對不起,你一定用了假的MVVM。

2.MVVM的核心在于ViewModel,那vm是一個怎樣的存在?

它剝離了c中的業務邏輯處理,讓c真正的成為一個傳輸數據樞紐!

它只需要從viewModel里拿到(get)數據,然后把數據放入(set)view里。

get和set是我對MVVM的理解,C?get VM生產的數據,set給V V賦值完成后由C展示。




結構圖:

上代碼:

Model:

#import

NS_ASSUME_NONNULL_BEGIN

@interfaceHomeModel :NSObject

@property (nonatomic, copy) NSString *userName;

@property (nonatomic, copy) NSString *userId;

@end

NS_ASSUME_NONNULL_END


ViewModel:

#import

#import "HomeModel.h"

NS_ASSUME_NONNULL_BEGIN

typedefvoid(^paramBlock)(HomeModel*model);

@interfaceHomeViewModel :NSObject

-(void)getDataWithRequestParam:(NSDictionary*)requestParam paramBlock:(paramBlock)paramBlock;

@end

NS_ASSUME_NONNULL_END


#import "HomeViewModel.h"

@implementation HomeViewModel

-(void)getDataWithRequestParam:(NSDictionary*)requestParam paramBlock:(paramBlock)paramBlock{

? ? //模擬網絡請求? 傳入請求參數requestParam

? ? HomeModel *model = [HomeModel new];

? ? model.userId=@"007";

? ? model.userName=@"zgj";

? ? //這里做個假數據,拿到數據做回調

? ? if(paramBlock) {

? ? ? ? paramBlock(model);

? ? }

}

@end


View:

#import

#import "HomeModel.h"

NS_ASSUME_NONNULL_BEGIN

@interfaceHomeTopView :UIView

-(void)setWithFrame:(CGRect)frame viewController:(UIViewController*)vc model:(HomeModel*)model;

@end

NS_ASSUME_NONNULL_END


#import "HomeTopView.h"

@implementation HomeTopView

-(void)setWithFrame:(CGRect)frame viewController:(UIViewController*)vc model:(HomeModel*)model{

? ? UILabel*nameLab = [[UILabelalloc]initWithFrame:CGRectMake(100,100,150,30)];

? ? nameLab.font= [UIFontsystemFontOfSize:20];

? ? nameLab.textColor=[UIColorblueColor];

? ? [selfaddSubview:nameLab];


? ? UILabel *idLab=[[UILabel alloc]initWithFrame:CGRectMake(100, 140, 150, 30)];

? ? idLab.font= [UIFontsystemFontOfSize:15];

? ? idLab.textColor =[UIColor redColor];

? ? [selfaddSubview:idLab];


? ? nameLab.text= [NSStringstringWithFormat:@"姓名:%@",model.userName];

? ? idLab.text= [NSStringstringWithFormat:@"ID:%@",model.userId];

? ? self.frame=frame;

? ? [vc.viewaddSubview:self];

}

@end


Controller:

#import "ViewController.h"

#import "HomeViewModel.h"

#import "HomeTopView.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {

? ? [super viewDidLoad];

? ? //get:獲取數據

? ? [[HomeViewModel new] getDataWithRequestParam:@{@"token":@"12345"} paramBlock:^(HomeModel * _Nonnull model) {

? ? ? ? //set:賦值

? ? ? ? [[HomeTopViewnew]setWithFrame:CGRectMake(0,0,self.view.bounds.size.width,400)viewController:selfmodel:model];

? ? }];

}

@end

最后用一張實踐圖詮釋MVVM的get和set理論:

在整個生命周期里,

M負責數據模型的生產,給VM用

VM負責邏輯處理和數據生產,交給C

C負責數據轉運(getVM的數據,set給V)和最后界面的加載展示工作

V負責把C傳過來的數據給UI賦值,然后展現在C上。


運行結果圖:


最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容