How to use MVVM in iOS - State Management and Data Flow through SwiftUI - Example Refactoring Swift

Поделиться
HTML-код
  • Опубликовано: 10 июл 2024
  • MVVM (Model - View Model - Model) Swift tutorial. MVVM is a design pattern recommend for SwiftUI 🤩. Next we will see what MVVM means and how it works with SwiftUI. A important part is to understand the data flow. We will see why we use ObservableObject and @Published.
    We will be talking about the declarative programming in SwiftUI, where "the truth" comes in. In the view part we will see the difference between @ObservedObject, @StateObject and @EnvironmentObject.
    We will use it to improve a sample project and take advantage of it when working in the preview and writing unit tests.
    Overview
    00:00 Introduction
    02:02 Coding example with bad practice
    09:48 How does Model - View Model - Model work ⭐️
    12:47 MVVM with SwiftUI: State management and data flow ⭐️
    26:02 Recoding our coding example to use MVVM
    35:58 Advantage of MVVM: dependency injection and showing different states of the view model in the preview
    40:56 Advantage of MVVM: easy to include unit testing for SwiftUI projects
    44:20 Wrap-up
    📖 I wrote a summary blog post about MVVM where you can find all the images from this tutorial here: www.swiftyplace.com/blog/swif...
    📖 You can read more about how to learn SwiftUI in this block post that I wrote a wile ago.
    / on-the-road-to-learn-s...
    If you liked what you learned and you want to see more, check out one of my courses!
    👨‍💻 my SwiftUI course school.swiftyplace.com/course...
    👨‍💻 my Core Data and SwiftUI course school.swiftyplace.com/course...
    👩🏻‍💻 Combine course school.swiftyplace.com/course...
    👉 Overview of Property wrappers in SwiftUI • Property wrappers in S...
    👉 @State vs @Binding • SwiftUI tutorial for B...
    👉 @ObservedObject vs. @StateObject • SwiftUI by example: @O...
    👉 @Published vs @State • @Published vs @State -...
    👉 AppStorage and SceneStorage • SwiftUI 2.0 tutorial -...
    #SwiftUI #Xcode #Programming #DesignPatterns

Комментарии • 129

  • @danielrybak4899
    @danielrybak4899 3 года назад +55

    The work that you put into this is simply amazing... I really hope you do more content!

  • @bonnydonny
    @bonnydonny 3 года назад +1

    I love the whole thing, especially the diagrams and high level overview. Great pace. Thank you!

  • @cortana2388
    @cortana2388 3 года назад +5

    I have watched many tutorials, they felt like the tutor have read something and delivering to us. But in this it feels like the content is created by her. Love from India.

  • @DavidRoth
    @DavidRoth 3 года назад +10

    PhysicsNerd is a treasure. This is a great accelerated walkthrough. I especially liked the clean code organization and the inclusion of basic unit tests. Great stuff.

  • @evennorthug2585
    @evennorthug2585 3 года назад

    This works for me. Momentum and depth. Keep up the good work!

  • @multitudes389
    @multitudes389 3 года назад

    with tests as well! truly a treat. Thank you!

  • @valentine1925
    @valentine1925 3 года назад

    I love your drawing/diagrams!! Thank you so much!!

  • @OIP_1
    @OIP_1 Год назад

    this is an awesome overview, thankyou!

  • @saradrada
    @saradrada Год назад

    This is amazing💖thank yo so much!

  • @tradingguy1004
    @tradingguy1004 3 года назад +3

    You are a great teacher, and these tutorials are really helpful and very informative...pleas keep on posting many many more of them :)

  • @kamilap3404
    @kamilap3404 2 года назад

    Thank you!! it was really helpful

  • @danialothman
    @danialothman 3 месяца назад

    what a wholesome video, thank you Karin!

  • @garymcc3748
    @garymcc3748 Год назад

    Really enjoying your courses Karin. Thank you!

  • @Titanman316
    @Titanman316 2 года назад

    This was exactly what I needed to fully understand how to do MVVM is SwiftUI. Thanks so much!!!

  • @jockeb7393
    @jockeb7393 3 года назад +2

    Thank you for this! You are an excellent teacher! 👍

  • @tharindudarshana6480
    @tharindudarshana6480 2 года назад

    Thank you very much. Amazing tutorial ♥

  • @dimitrikirillov2913
    @dimitrikirillov2913 3 года назад +1

    Thanks! Herzlichen Dank! Sehr informativ. Keep up good work!

  • @javigarcia-ripoll6578
    @javigarcia-ripoll6578 2 года назад

    You're the best! Thank you!

  • @ChuckDiggins
    @ChuckDiggins 3 года назад

    You are very thorough. It helps as you think out loud as show your drawings. Thank you.

  • @blueducktrading
    @blueducktrading 3 года назад +1

    This is brilliant. Thank you for providing such a detailed overview of MVVM, providing an example and simplifying it all to make it really easy to understand. I have been looking for something just like this!
    Another video very similar to this showing people how to do exactly the same process, but with Firebase: FireStore read/write etc. instead of local data would also be a great addition in my opinion. There really isn't any videos that i've managed to find that break firebase down into a simplistic app...I think people would benefit greatly from it.
    Thanks again.

  • @stanleymiller1181
    @stanleymiller1181 3 года назад +1

    Excellent detailed explanation. Much appreciated.

  • @ricardokuster
    @ricardokuster 3 года назад

    Hi Karin, love the way you explain things ! Like a PRO ! Merci beaucoup !

  • @arsenidziamidchyk2972
    @arsenidziamidchyk2972 2 года назад

    Reaaally good tutorial, thanks a lot!

  • @manwithllama
    @manwithllama Год назад +1

    Your drawings are so helpful! Especially the one at 9:59. That feels to be really clicking for me. Thank you for putting all the hard work into this video.

  • @Flintalt2
    @Flintalt2 3 года назад

    Fantastic video, very nicely explained and great visuals describing everything! Thank you

  • @jonathanpiette
    @jonathanpiette 2 года назад

    Amazing! Thank you for this video of quality

  • @pepesilvia1055
    @pepesilvia1055 2 года назад

    great video! thanks for making it 👍😘

  • @ekadam
    @ekadam Год назад +2

    Many many thanks for your videos. Especially the details you go into with so many diagrams. Please continue doing so. When my first app goes live, I hope I can donate a part to you and other amazing teachers I learnt from.

  • @christianredlich1305
    @christianredlich1305 3 года назад +9

    The First MVVM-Tutorial, which I completely understood... Thank you for your work and nice and understandable drawings.

  • @mojota6938
    @mojota6938 2 года назад

    Fantastic presentation. Everything is super clear, thank you very much!!!

  • @user-in7yn4qw3g
    @user-in7yn4qw3g 6 месяцев назад

    Superb content Karin, helped me immensely x

  • @anantdesai3293
    @anantdesai3293 2 года назад +3

    I love the way you put all the things separately and properly while explaining. Thanks for this tutorial. I was totally confused about the SwiftUI lifecycle and structure. But after watching your videos, it helps me to understand it easily. Right now I can say that I have some better idea about the SwiftUI. Thanks once again. ❤️

  • @muncho404
    @muncho404 2 года назад

    Your tutorials are 💎

  • @ashoms0a
    @ashoms0a 2 года назад

    Very well explained! Thank you!

  • @berkc5323
    @berkc5323 2 года назад

    you are amazingg thanks!!!

  • @jordibruin
    @jordibruin 3 года назад

    Very clear, thanks a lot!

  • @williamallen4607
    @williamallen4607 3 года назад +1

    You have a great skill for teaching. Your explanations are so detailed and helpful. Thank you.

  • @SuInTheDev
    @SuInTheDev 2 года назад

    wow, this is so nice explanation!

  • @foggydawning9268
    @foggydawning9268 2 года назад

    Wow! Amazing video !!!

  • @MayurPatilishere
    @MayurPatilishere 11 месяцев назад

    Thanks for such an informative tutorial.

  • @TheDALLADER
    @TheDALLADER 3 года назад

    Great work! I hope this video gets more attention.

  • @ZachMatics
    @ZachMatics 11 месяцев назад

    Gorgeous. Subscribed!

  • @Histats71
    @Histats71 3 года назад

    This work is amazing. Thanks for everything

  • @pgong415
    @pgong415 Год назад

    Hi Karin, thumbs up! amazing! Thanks a lot for your efforts for this fantastic video! Absolutely useful! Great!

  • @samurai7938
    @samurai7938 10 месяцев назад

    I am treated up for your videos. Please keep it up.

  • @jiaweil902
    @jiaweil902 3 года назад

    Thank you so much! It's easy to understand!! I really love those faces!

  • @UMBerto-wj7ch
    @UMBerto-wj7ch 3 года назад

    Superb video, right to the point!

  • @ksufed8918
    @ksufed8918 3 года назад

    Very helpful, thanks a lot! ❤️👍

  • @hcri
    @hcri 3 года назад +1

    You are a very good instructor. Wishing you good luck and I will be following you closely.

  • @mafiaboy16
    @mafiaboy16 2 года назад

    The way this Tutorial is setup, is super and i just want to learn more

  • @jayantkumar1954
    @jayantkumar1954 2 года назад +1

    amazing!!

  • @kevinmichaelallen1
    @kevinmichaelallen1 Год назад

    This is exactly what I've been searching for. I'm have a lot of experience with MVVM in C# WPF applications. I'm starting a new project on iOS and this video gives me everything I need to get to work.

  •  2 года назад

    Dear Karin, great content, thank you :-)

  • @paulfranco5733
    @paulfranco5733 3 года назад

    I really enjoy your content.

  • @AndrewDChristie
    @AndrewDChristie 4 месяца назад

    Thanks!

  • @eminemmatters3055
    @eminemmatters3055 2 года назад

    you're amazing! thank you thank you thank you :)

  • @sebastianstaszczyk5240
    @sebastianstaszczyk5240 3 года назад +1

    Awesome tutorial! You are the best. 👍
    If you have time, I would be very grateful for showing how to use MVVM with CoreData in SwiftUI. Thanks!

  • @Grepsoft
    @Grepsoft 2 года назад

    Good explanation and the diagrams were really well done. Thank you for the content.

  • @cassenhari3992
    @cassenhari3992 2 года назад

    you are the greatest have a good year

  • @napalm_exe
    @napalm_exe 3 года назад

    Amazing tutorial. I come from an Android background but this was definitely easy to follow along. Would definitely pay for any courses you have if they're anything like this.

  • @--..FC..--
    @--..FC..-- Год назад

    nice work

  • @girishadapa90
    @girishadapa90 3 года назад

    Your way of explanation 🎉 something special madam 👍

  • @alanyang8752
    @alanyang8752 3 года назад +1

    Thank you

  • @test-t-e8s
    @test-t-e8s 3 года назад

    good!! Awsome lecture!

  • @francislegaspi2923
    @francislegaspi2923 2 года назад +5

    Wow as an Intermediate~Advance iOS Developer, this is very concise and easy to understand, straight to the point, I love when you explaining with drawings, you're a natural Teacher, Thank you Karin! you earned my Subscription :D

  • @nickcostello2810
    @nickcostello2810 3 года назад

    I think I've watched this three times now. I watched it two months ago when I first started my app. Lost appreciation for MVVM. Now that I have a fairly complex app... my appreciation is back.

    • @SwiftyPlace
      @SwiftyPlace  3 года назад

      I am very happy that you could gain this understanding. It is hard to show a larger project in a tutorial.
      But this is exactly when MVVM helps to organise the code.

  • @fredrigaudeau
    @fredrigaudeau 3 года назад +1

    This video is by far the best I could find to finally understand MVVM and property wrappers. Thanks a lot.
    I have small side question regarding the Test project: when you added the ZStack, the background of the app became gray. I couldn't figure out how to make it back to white. Why did it became gray and how to change it?

  • @emresancaktaroglu6430
    @emresancaktaroglu6430 3 года назад

    Hello,
    First of all, thank you for your information. I don't understand how you did it in 45 min. But, you have explained all of the critical information about MVVM, Property Wrappers, SwiftUI etc. You are a really incredible teacher. If you speak a little slower than normal it would be perfect for people whose doesn't native language is English. I watched with 0.75 :)
    I became your huge fan!

  • @lennyedwards62
    @lennyedwards62 3 года назад

    This is great. I bought both your udemy courses.

  • @The1tjc
    @The1tjc 3 года назад +1

    Cool visuals!

    • @SwiftyPlace
      @SwiftyPlace  3 года назад +1

      All done on my iPad with my Apple pencil. Feels like I can use a white board. 🤓

    • @TechRagh
      @TechRagh 3 года назад

      Done using Procreate on ipad? Very nice visuals. Please do more videos on SwiftUI

    • @SwiftyPlace
      @SwiftyPlace  3 года назад

      @@TechRagh Procreate is to much functionality for me. This is made with my own app. Still very buggy. But you can try it here apps.apple.com/us/app/assocy-the-genius-notebook/id1464579365

  • @patratacus
    @patratacus 2 года назад +1

    Great video! This helps me a lot in learning MVVM. Would you be able to update this for Xcode 13 and SwiftUI 5? NavigationView has drastically changed so a lot of the codes here no longer function as well.

  • @abdullohbahromjonov781
    @abdullohbahromjonov781 4 месяца назад

    3:00 background cat >>>>>>

  • @developer8995
    @developer8995 3 года назад

    You did a great job 👏 thank you very much! May I ask, are you from Germany ?

  • @schmittsfn
    @schmittsfn 3 года назад

    Really enjoying your videos. One thing that would interest me is how one would combine MVVM with the Coordinator pattern in modern Swift. Or are there better patterns for navigating in huge projects?

  • @monacvelf3124
    @monacvelf3124 3 года назад

    Hi Karin, deine Art zu erklären gefällt mir wirklich sehr gut. Ich würd mich sehr freuen, wenn du ein Video zum Thema APIs machen könntest. Vielleicht auch mal eine Zusammenfassung deiner liebsten Swift Bücher/ Lernunterlagen, Tipps etc.
    Weiter so!

    • @SwiftyPlace
      @SwiftyPlace  3 года назад +3

      Hi Mona, freut mich dass dir meine Erklärungen gefallen. Ich wollte noch ein paar Videos zu Combine machen und die integration mit Core Data und realm. Ich werde mal sehen was ich für ein video zum Thema "Wie kann man Swift und UIKIt / SwiftUI lernen" machen kann.

  • @KimbrellBrad
    @KimbrellBrad Год назад

    Love listening to your videos but I cannot take the bright white screen. Would you consider using dark mode? Most agree that the contrast is much better and easier on the eyes. I haver glaucoma and it is tough with sight only in my right eye. I appreciate what you do and either way will continue listening!

  • @jarodpaulson9439
    @jarodpaulson9439 2 года назад

    Hi Karin, great video, thanks so much for making it. I did have a question about some other file groups that I have seen in people's project, like services, extensions, utilities, and repositories. How do these elements fit into the MVVM blueprint you've discussed here? Thanks.

  • @AMchou
    @AMchou 3 года назад +1

    Hi,
    Thanks a lot for the info, it was very helpful. When you create the Navigation Link for the name, if you wanted to have a more detailed view and perhaps edit details of "name" would it be necessary to create an entirely new view or could we incorporate a func in the VM to do so?

  • @Pro-jz8wg
    @Pro-jz8wg 3 года назад +1

    big thanks for your work!!great tutorial!!!
    how can I get this wonderful SwiftUI road map?)
    //I really need it

  • @diaryofdreamsnaveed
    @diaryofdreamsnaveed 2 года назад

    Subscribed

  • @a3r0phil
    @a3r0phil 3 года назад

    Nice work! May I ask what do u use for these beautiful diagrams?

  • @victorriurean
    @victorriurean 2 года назад

    nice

  • @teeks4geeks
    @teeks4geeks 2 года назад

    Thank you. You explained it very well! Where should I create other view models? For example, I want to create another view model for editing items, so the model will represent a single item. Should I create an instance of that view model inside the main view model, or in the view itself or something else?

  • @brunokd2
    @brunokd2 Год назад

    Very good video. How can I modify the state of a view model from another view model? Should I do it or do it from another way?

  • @tttopcattt
    @tttopcattt 3 года назад

    Hi Karin, thank you for providing such clarity on this subject. Suppose you want to maintain persistent data in a json file. What might be the simplest method to maintain one 'persistent' data source? My efforts are fraught with mutability issues. TIA

  • @amphortas1
    @amphortas1 2 года назад

    Thank you very much for your amazing work! May I ask you a question please? If I wanted to have a list of words (for example, English words with translation) already pre-populated, is it okey to use such an approach with a StateManager.fullState() or what is a best approach for such this cases?

  • @georgh.9814
    @georgh.9814 3 года назад

    Very interesting and well explained. A little bit to fast, but i can stop and watch parts again. Could you please make a video how to handle CoreData with models. E.g. Players and statistics stored in coredata and use them in a model (maybe a simple game)? Whats the way to go using coredata objects in other models?

  • @chrisual
    @chrisual 3 года назад +2

    This is an amazing video. Are the diagrams your own? They should be in the official docs!

    • @SwiftyPlace
      @SwiftyPlace  3 года назад

      Thanks for the nice words. The drawings are all mine. If the official docs get more images like these, I would be super happy too. I need to see visuals to understand.

  • @AkamiChannel
    @AkamiChannel 2 года назад

    Excellent video. If you could do dark mode, reading the code would be a little easier on the eyes.

  • @amphortas1
    @amphortas1 2 года назад

    Do you have any Udemy courses, I will be happy to buy it and study from you! Your explanation is awesome! I finally understood MVVM approach with CRUD (Create, Read, Update, Delete) operations and example of simple tests! Amazing training!

  • @saeedhajizadeh5552
    @saeedhajizadeh5552 2 года назад +1

    The cat in the background is sooo cute that I can't focus on the actual tutorial

    • @SwiftyPlace
      @SwiftyPlace  2 года назад

      That is Louis job as cohost. He is very good at being cute. 🤩

  • @LucasFernandesSilveira
    @LucasFernandesSilveira 3 года назад

    Awesome content! Thanks 😊
    Is this presentations available download for further checks?

    • @SwiftyPlace
      @SwiftyPlace  3 года назад +1

      I summarised the video in this blog post www.swiftyplace.com/blog/swiftui-and-mvvm. You can find all the images there.

    • @LucasFernandesSilveira
      @LucasFernandesSilveira 3 года назад

      @@SwiftyPlace great! I’ll check it out. Thanks for this 👏

  • @asseeger
    @asseeger 3 года назад

    Awesome content, thanks a lot! What is your solution to handing down instances to the detail view from a list to let the user make changes (like e.g. changing the todo's title-as your are handing down an unmutable instance from within the closure, you do not have a binding... Right now, I create a binding myself in the detail view by finding the instance via it's `id` in the view models array, but I do wonder if there is a better way to do this...

    • @SwiftyPlace
      @SwiftyPlace  3 года назад +1

      I think changing the item in the item array by id, is a feasible approach. Not sure if there is a different way because your data always is represented by this data array and that is the one that needs to be changed.
      For the title I would have an extra @Published property in the view model. In order to let the user change it, I would show an extra editor view with a textfield. The view gets access to the view model with @ObservableObject or directly to the view models property with @Binding.

  • @HilaProdomo
    @HilaProdomo 2 года назад

    Thank you for this video. Where do you manage @FetchRequest with CoreData? IMO it should go in the ViewModel. Or do you use it in the View directly?

    • @SwiftyPlace
      @SwiftyPlace  2 года назад

      It would be great if we could use @FetchRequest in a view model. This will not work because it needs the NSManagedContext that has to be added in the environment with .environment\.managedObjectContext, context)
      Core Data with MVVM is a bit more tricky. I explain more about it in this Core Data specific tutorial ruclips.net/video/63oyC5bUujc/видео.html

  • @SOK-gn6hw
    @SOK-gn6hw Год назад

    Hi in the beginning of the video there is a beautiful road map. How can I reach that ?

  • @thomasvalter333
    @thomasvalter333 3 года назад +1

    This is indeed a fantastic tutorial. Even as a beginner, I understand most, thank you!
    One question if you (or others) don't mind.
    You have talked about how a ViewModel interacts with a View.
    But what do you do, if you have two ViewModels and want them to interact?
    I have tried in ViewModel A to add ViewModel B as an @StateObject (get an error: )
    weird

    • @asseeger
      @asseeger 3 года назад

      That's a good question that I have asked myself as well-I guess what it comes down to is to find a spot in your application where you have access to both of the view models (most likely the spot where they are created), passing down a reference to the respective other view model. Those could be optional properties, I guess.

    • @pandalanhukuk804
      @pandalanhukuk804 2 года назад

      You should go one more time to the Video all the drawings. To ViewModel is interacting with the Model.

  • @SwiftyPlace
    @SwiftyPlace  3 года назад +1

    If you prefer a written tutorial, you can go to my new blog www.swiftyplace.com/blog/swiftui-and-mvvm. The code and images are available too.

  • @cuongnt04230
    @cuongnt04230 2 года назад

    Could you share the image swiftui roadmap? Thanks

    • @LeviM337
      @LeviM337 2 года назад

      It's in her description: karinprater.medium.com/on-the-road-to-learn-swiftui-8b26b528199c

  • @andrewiglinski148
    @andrewiglinski148 3 года назад

    PhysicsNerd?!?! I majored in Physics and I'm just now getting into Swift after working with Kotlin and Node for a while. What got you into development instead of working in something like academia related to physics?

  • @mhfs61
    @mhfs61 3 года назад

    👍🏼👍🏼👍🏼