mvvm oc 框架_iOS MVVM架构

本文介绍了iOS开发中从MVC到MVVM架构的演变,阐述了MVVM各组成部分的职责,并通过实例比较了MVC与MVVM在处理同一需求时的区别,强调了MVVM如何帮助减少ViewController的复杂性,提高代码可维护性。
摘要由CSDN通过智能技术生成

iOS中,我们使用的大部分都是MVC架构虽然MVC的层次明确,但是由于功能日益的增加,代码的维护,更多的代码被写在了Controller中,这样Controller就显得非常臃肿。

为了给Controller瘦身,后来又从MVC衍生出了一种新的架构模式MVVM架构

MVVM分别指什么

Model-数据层

ViewController/View-展示层

ViewModel- 数据模型

MVVM与MVC的不同

首先我们简化一下MVC的架构模式图:

MVC.png

在这里,Controller需要做太多得事情,表示逻辑、业务逻辑,所以代码量非常的大。而MVVM:

MVVM.png

比如我们有一个需求:一个页面,需要判断用户是否手动设置了用户名。如果设置了,正常显示用户名;如果没有设置,则显示“简书0122”这种格式。(虽然这些本应是服务器端判断的)

我们看看MVC和MVVM两种架构都是怎么实现这个需求的

MVC:

Model类:

#import

@interface User : NSObject

@property (nonatomic, copy) NSString *userName;

@property (nonatomic, assign) NSInteger userId;

@end

ViewController类:

#import "HomeViewController.h"

#import "User.h"

@interface HomeViewController ()

@property (nonatomic, strong) UILabel *lb_userName;

@property (nonatomic, strong) User *user;

@end

@implementation HomeViewController

- (void)viewDidLoad {

[super viewDidLoad];

if (_user.userName.length > 0) {

_lb_userName.text = _user.userName;

} else {

_lb_userName.text = [NSString stringWithFormat:@"简书%ld", _user.userId];

}

}

这里我们需要将表示逻辑也放在ViewController中。

MVVM:

Model类:

#import

@interface User : NSObject

@property (nonatomic, copy) NSString *userName;

@property (nonatomic, assign) NSInteger userId;

@end

ViewModel类:

声明:

#import

#import "User.h"

@interface UserViewModel : NSObject

@property (nonatomic, strong) User *user;

@property (nonatomic, copy) NSString *userName;

- (instancetype)initWithUser:(User *)user;

@end

实现:

#import "UserViewModel.h"

@implementation UserViewModel

- (instancetype)initWithUser:(User *)user {

self = [super init];

if (!self) return nil;

_user = user;

if (user.userName.length > 0) {

_userName = user.userName;

} else {

_userName = [NSString stringWithFormat:@"简书%ld", _user.userId];

}

return self;

}

@end

Controller类:

#import "HomeViewController.h"

#import "UserViewModel.h"

@interface HomeViewController ()

@property (nonatomic, strong) UILabel *lb_userName;

@property (nonatomic, strong) UserViewModel *userViewModel;

@end

@implementation HomeViewController

- (void)viewDidLoad {

[super viewDidLoad];

_lb_userName.text = _userViewModel.userName;

}

可见,Controller中我们不需要再做多余的判断,那些表示逻辑我们已经移植到了ViewModel中,ViewController明显轻量了很多。

总结:

MVVM同MVC一样,目的都是分离Model与View,但是它更好的将表示逻辑分离出来,减轻了Controller的负担;

ViewController中不要引入Model,引入了就难免会在Controller中对Model做处理;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值