Skip to content

Latest commit

 

History

History
82 lines (55 loc) · 6.91 KB

README.md

File metadata and controls

82 lines (55 loc) · 6.91 KB

This document includes personal answers/declarations of the most curious subjects and asked questions about iOS development.

Subjects

System Requirements

You need a MacOS to run Xcode and Simulator, therefore the best device is MacBook for them. You can also give a chance to iMac and Mac mini but I assume that you will use the computer also outside of home.

Minimum system requirements must be Intel i5 processor, 16GB Ram, 256GB SSD.

The highly recommended system requirement is M1 processor, 16GB Ram, 512GB SSD. These requirements provide an excellent working environment without any delay/lagging. You are also free to consider getting 256GB SSD instead of 512.

You will probably go with the Intel chips and old MacBooks if you have a limited budget. Consider choosing MacBook Pro then, I don't recommend MacBook Air with Intel chips. You will have some performance issues.

Things change when it comes to M1 chip. It is quite perfect for performance. No fan, high performance at all. If the budget is still limited, I highly recommend upgrading the chip from Intel to M1, which is worth it. M1 is two times better than an average i5 processor, here is the benchmark result
The ram still can be 16GB, and SSD 256 or 512GB.

When M1 is your choice, you can go with MacBook Air, which is lighter than Pro. It only has %5 less performance than Pro, which is almost not even comparable.
In 2022, I am currently using M1 MacBook Air with 16GB Ram, 256GB SSD in professional iOS development.

Course Suggestion

Good course, good start. Hence, I suggest these,

Building UI, Storyboard vs Programmatically

Well, I know only a few people who like storyboards(some of them are already the developers who built storyboard). In case you are in the beginning of your iOS development career, you absolutely should start with Storybard to build UI. When the situation is visualized, human brain gets the situation easier. You should focus on auto layout first by getting help from visualizing.

I prefer building UI programmatically like most developers. Storyboard or XIB files are not useful in my opinion. When you open a storyboard and focus on a view that has a lot of subviews aligned vertically, just take one of them in the middle and move to the bottom. The view will look like some crazy stuff happened. Visualizing will not help you anymore.

On the other hand in building UI programmatically, you only care about the anchors(constraint positions) of the views. You can easily change/switch anchors because they are in a class. I recommend using SnapKit to build UI programmatically. It provides a cool and clear syntax. You can also create your NSLayoutConstraint extensions.

First Fundamentals That Should be Known

1- Architecture

Check here out for MVC and MVVM. They are the architectures you highly should know with their details.

What are the weaknesses of MVC?

The controller represents the both view and controller(logic). Therefore, the controller gets heavy by time because it stores both logic and UI code blocks.

What makes MVVM more preferable than MVC?

It is because implementing MVVM is simple over MVC. All you need to do is creating a view model and initializing an instance of the view model in the controller.

What are the differences between them?

The logic part goes into the view model from the controller in MVVM. MVC still stores the logic part.

What should/not the view model include, why?

The view model should be responsible only for the logic part, not UI. Therefore, it should not import UIKit.

2- Responsive Design

Apple ecosystem has different type of devices such as iPhone, iPad, Apple TV. Screens must looking almost the same on every design.

You should able to handle the UI both storyboard and programmaticly. These principles will give you an open mind to build the UI.

Check the building UI part in this article.

3- Network Layer

Every cool app needs a network communication with a backend service. We are supposed to make a clean, understandable, scalable network layer. It should be great if it supports generic types which provides flexibility for the response model will be parsed.

I have an article about the generic network layer here.

Try to build the network layer by separating it 2 parts.

1- Base(Network Manager)

It is only responsible to parse the data. No specific conditions, endpoint logics, etc. Since it is generic, it even does not know the parsing model.

2- Middle Layer(Services)

It is a bridge between the place which calls the network layer and the base network manager.

Imagine that the view model calls here, the middle layer calls the network manager, the network manager returns the parsed response to the middle layer, and the middle layer returns the response to the view model.

I prefer to separate services by endpoints. For example, I have an endpoint like that, https://baseUrl.com/users/login. I create UsersService class for its sub-endpoints. The UsersService will have the login function to call the users/login endpoint. The function declares the request specifications(method, endpoint url, response class) and calls the network manager. By separating like that, I can easily add new services and functions without breaking the current/old service calls.

Questions

Which One Should I Start with, UIKit or SwiftUI?

In 2022, most companies still use UIKit actively. In case you work for a company, you will most probably face with a project written in UIKit, not SwiftUI. Also, SwiftUI has still some weaknesses rather than UIKit. When you come over a weakness of SwiftUI, you must build a bridge via UIKit by using UIViewRepresentable. You must have UIKit knowledge to build that bridge.

In conclusion, it is better to start with UIKit. After you have a job and you feel that you are okay with UIKit knowledge, you are free to improve our SwiftUI skills in your free time except during working hours.