Fully updated for Xcode 11.4
This is a complete, free SwiftUI tutorial designed to take you through lots of its functionality in a single project. It’s aimed at people who have existing programming experience with UIKit, but most things are explained in detail so newcomers ought to be able to follow along.
The project we’ll be making is called iDine, and is a restaurant app that lists items in a menu and helps folks place orders. I’ve designed the project specifically so that it covers as many different techniques as possible to give you a good grounding in how things work in SwiftUI. Of course, we’re also building a real project at the same time – it’s going to be busy!
Advance warning: It’s really easy to make mistakes in SwiftUI, and right now the errors generated by the compiler are less than helpful – you might get a complaint about line 8 when really the problem is on line 23, or when the error is on the right line it’s sometimes something obscure. These problems are, for now at least, perfectly normal.
To get started, please create a new iOS project in Xcode called “iDine”, choosing the Single View App template and choosing SwiftUI for the User Inteface.
There are quite a few assets provided for this project that you need to copy in before you start. These are all in the assets for this project, which you can download here: https://www.hackingwithswift.com/samples/idine.zip.
Please copy them into your project like this:
Codabledata from a bundle. This is a pre-iOS 13 thing, so we won’t be covering it here.
OK, that’s it – we’re ready to go!
Tip: At the end of each chapter I’ve added a “Further reading” section that suggests links to other chapters in this book. You don’t need to read them in order to follow along; they are there to provide extra information and detail if you want to understand the bigger picture more thoroughly.
SPONSORED Catch bugs as soon as they happen and know exactly why a crash occurred by integrating Instabug's SDK in one minute. You will automatically receive device data, network logs, and reproduction steps with every bug and crash report.
Link copied to your pasteboard.