preface

In the actual development, in order to ensure that the product can be launched as perfect as possible, we will specially test several rounds before launching, to ensure that the developed application has no problems. However, it can also ensure that some garbage data in the test does not affect the online version data. At this time, it is necessary to distinguish the production environment. Generally, a test environment will be prepared specifically for the test during the test, and the test environment will be changed into the corresponding online environment during the online to achieve the purpose of online.

When to switch from the environment, the simplest method is to modify the global public interface, do indeed can satisfy the requirements on environment switch, however, if the testers to ask you also distinguish somewhat above the icon of the products, such as the App icon, start, figure, etc., when the online icon with a test environment is inconsistent with the icon, It becomes a little more cumbersome because you not only have to switch interfaces, but you also have to go back and forth to change the environment icon each time.

In addition to the above situation, some apps are also divided into professional version and ordinary version, and the difference between professional version and ordinary version lies in whether there are some functions. For such requirements, is it necessary to separate the two projects? If two projects are specially separated, then after iteration, both projects have to be iterated at the same time, the workload is so huge, and a single copy is not a good method in the design.

So to solve this problem, versioning projects (beta, online, etc.) with multiple targets can be done using the method described today.

define

Before using it, let’s take a look at what apple’s official documentation says about Target, as follows:

A target specifies a product to build and contains the instructions for 
building the product from a set of files ina project or workspace. A target defines a single product; It organizes the inputs into the build system -- thesource files and instructions for processing those sourceFiles - required to build that product. Projects can contain one or more targets, each ofwhich produces one product.
Copy the code

A Target defines a single project environment, which can contain one or more targets within a project. This means that multiple environments can be set up in a project.

use

There are two ways to create a Target:

  • directlycopyTarget configuration in previous projects;
  • Create a new Target configuration.

Next, follow the steps.

  • Step 1: Create Target

To Duplicate existing targets in the project, click Duplicate

If you want to create a new Target, use the following method:

  • Step 2: ChangeTargetThe name of the

After you create Target, you will find the word copy after the name, suddenly think amateur not good? In this case, we can change the name through the following method.

  • Step 3: Add differentTargetUnder the app icon

In order to meet the needs of changing ICONS in different environments in the project, we can use this method.

  • Step 4: Configure global macros to differentiate environments in your code

In OC, only the following methods are used to distinguish environments

#import "ViewController.h"

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    UIView *view1 = [[UIView alloc]initWithFrame:CGRectMake(100, 100, 150, 150)];
    UIView *view2 = [[UIView alloc]initWithFrame:CGRectMake(100, 100, 150, 150)];
    
    view1.backgroundColor = [UIColor blackColor];
    view2.backgroundColor = [UIColor yellowColor];
    
    


#if TARGET_VERSION == 1

    [self.view addSubview:view1];   
#else

    [self.view addSubview:view2];
#endif
    

}

Copy the code

In Swift, the following method is used to distinguish the corresponding environment

import UIKit

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
        
        let view1 = UIView.init(frame: .init(x: 100, y: 100, width: 150, height: 150));
        let view2 = UIView.init(frame: .init(x: 100, y: 100, width: 150, height: 150));
        
        view1.backgroundColor = UIColor.black;
        view2.backgroundColor = UIColor.yellow;
        
        #if DEVELOPMENT
            self.view.addSubview(view1);
        #else
            self.view.addSubview(view2);
            
        #endif
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }


}

Copy the code

By compiling different targets, we can get apps in different environments, as shown below:

Extension (use of Cocopads)

When using cocopods management, we should not forget to add these frameworks to the corresponding Target. Otherwise, we may not find the corresponding framework when using POD, we can refer to the following code to build:

platform :ios, '7.0'
workspace 'TestTargetDemo'
link_with 'TestTargetDemo'.'TestTargetDemoDev'
pod 'SDWebImage'
pod 'AFNetworking'
Copy the code

conclusion

By using different targets to manage the configuration files of our different environments, it greatly simplifies the time of switching between environments, makes our development work easier, and in a sense improves our development efficiency, doesn’t it?