zoukankan      html  css  js  c++  java
  • 《iOS应用架构谈 view层的组织和调用方案》笔记整理

    结束前段时间的忙碌,近来工作没什么任务。就趁上班时间学习一点东西。

    读完了Casa Taloyum的《iOS应用架构谈 view层的组织和调用方案》,写的很认真,很详尽,收获颇丰。着手整理下目前自己能领悟到的一些知识。

    先分享下:http://casatwy.com/iosying-yong-jia-gou-tan-viewceng-de-zu-zhi-he-diao-yong-fang-an.html

    代码结构

      先声明一点,我们之所以注重代码结构和格式,是为了代码的可读性和后期的可维护性,当然仅仅凭此文中讲的,还不够。还应该再去了解下变量和方法的命名规则等,推荐一本书:effctive objective-c 2.0。另外对于一个码农来讲,每天面对“一坨”似的代码和结构清晰、格式整齐的代码,你想要哪个呢?好了,不啰嗦了。

    直接上代码:

    @interface ViewController ()
    
    #pragma mark - propertys
    @property (nonatomic, strong) UIButton *customBtn;
    
    @end
    
    @implementation ViewController
    
    #pragma mark - life cycle
    - (void)viewDidLoad;
    - (void)viewDidAppear:(BOOL)animated;
    - (void)viewWillAppear:(BOOL)animated;
    .........
    
    #pragma mark - UITableViewDelegate
    .........
    
    #pragma mark - CustomDelegate Or OtherDelegate
    .........
    
    #pragma mark - event response
    .........
    
    #pragma mark - private methods
    .........
    
    #pragma mark - getters and setters
    .........
    
    @end

    详细说明下:

    1.所有的属性都使用getter和setter

      不要在viewDidLoad里面初始化你的view然后再add,这样代码就很难看。在viewDidload里面只做addSubview的事情,然后在viewWillAppear里面做布局的事情,最后在viewDidAppear里面做Notification的监听之类的事情。至于属性的初始化,则交给getter去做。

    比如这样:

    #pragma mark - life cycle
    - (void)viewDidLoad
    {
        [super viewDidLoad];
    
        self.view.backgroundColor = [UIColor whiteColor];
        [self.view addSubview:self.firstTableView];
        [self.view addSubview:self.secondTableView];
        [self.view addSubview:self.firstFilterLabel];
        [self.view addSubview:self.secondFilterLabel];
        [self.view addSubview:self.cleanButton];
        [self.view addSubview:self.originImageView];
        [self.view addSubview:self.processedImageView];
        [self.view addSubview:self.activityIndicator];
        [self.view addSubview:self.takeImageButton];
    }
    
    - (void)viewWillAppear:(BOOL)animated
    {
        [super viewWillAppear:animated];
    
        CGFloat width = (self.view.width - 30) / 2.0f;
    
        self.originImageView.size = CGSizeMake(width, width);
        [self.originImageView topInContainer:70 shouldResize:NO];
        [self.originImageView leftInContainer:10 shouldResize:NO];
    
        self.processedImageView.size = CGSizeMake(width, width);
        [self.processedImageView right:10 FromView:self.originImageView];
        [self.processedImageView topEqualToView:self.originImageView];
    
        CGFloat labelWidth = self.view.width - 100;
        self.firstFilterLabel.size = CGSizeMake(labelWidth, 20);
        [self.firstFilterLabel leftInContainer:10 shouldResize:NO];
        [self.firstFilterLabel top:10 FromView:self.originImageView];
    
        ... ...
    }

    这样即便在属性非常多的情况下,还是能够保持代码整齐,view的初始化都交给getter去做了。总之就是尽量不要出现以下的情况:

    - (void)viewDidLoad
    {
        [super viewDidLoad];
    
        self.textLabel = [[UILabel alloc] init];
        self.textLabel.textColor = [UIColor blackColor];
        self.textLabel ... ...
        self.textLabel ... ...
        self.textLabel ... ...
        [self.view addSubview:self.textLabel];
    }

    这种做法就不够干净,都扔到getter里面去就好了。

    2.getter和setter全部都放在最后

      因为一个ViewController很有可能会有非常多的view,就像上面给出的代码样例一样,如果getter和setter写在前面,就会把主要逻辑扯到后面去,其他人看的时候就要先划过一长串getter和setter,这样不太好。然后要求业务工程师写代码的时候按照顺序来分配代码块的位置,先是life cycle,然后是Delegate方法实现,然后是event response,然后才是getters and setters。这样后来者阅读代码时就能省力很多。

    3.每一个delegate都把对应的protocol名字带上,delegate方法不要到处乱写,写到一块区域里面去

      比如UITableViewDelegate的方法集就老老实实写上#pragma mark - UITableViewDelegate。这样有个好处就是,当其他人阅读一个他并不熟悉的Delegate实现方法时,他只要按住command然后去点这个protocol名字,Xcode就能够立刻跳转到对应这个Delegate的protocol定义的那部分代码去,就省得他到处找了。

    4.event response专门开一个代码区域

      所有button、gestureRecognizer的响应事件都放在这个区域里面,不要到处乱放。

    5.关于private methods,正常情况下ViewController里面不应该写

      不是delegate方法的,不是event response方法的,不是life cycle方法的,就是private method了。对的,正常情况下ViewController里面一般是不会存在private methods的,这个private methods一般是用于日期换算、图片裁剪啥的这种小功能。这种小功能要么把它写成一个category,要么把他做成一个模块,哪怕这个模块只有一个函数也行。ViewController基本上是大部分业务的载体,本身代码已经相当复杂,所以跟业务关联不大的东西能不放在ViewController里面就不要放。另外一点,这个private method的功能这时候只是你用得到,但是将来说不定别的地方也会用到,一开始就独立出来,有利于将来的代码复用

    6.为什么要这样要求?

      ViewController,代码布局乱得一塌糊涂,这里一个delegate那里一个getter,然后ViewController的代码一般都死长死长的,看了就让人头疼。定义好这个规范,就能使得ViewController条理清晰,业务方程序员很能够区分哪些放在ViewController里面比较合适,哪些不合适。另外,也可以提高代码的可维护性和可读性。

      

  • 相关阅读:
    有固态硬盘的电脑还是不流畅?这些值得了解
    一名神舟笔记本电脑用户的内心独白
    验证码无法显示:Could not initialize class sun.awt.X11GraphicsEnvironment 解决方案
    nginx 负载均衡时,一台tomcat宕机时的问题 自动切换
    tomcat结合nginx使用小结
    金九银十面试突击,卧底去阿里、京东、美团、腾讯带回来的面试题(内含答案)
    干货分享 ▏Jmeter-场景设置/运行/参数化访问地址/【一次性打包呈现】
    各类APP功能测试用例/设计方法/数据库和日记分析——【范本】
    软件测试这些坑,千万不要踩!
    技术面试中,遇到不会回答的问题怎么破?来,教3招!
  • 原文地址:https://www.cnblogs.com/ioshevin/p/4531657.html
Copyright © 2011-2022 走看看