8 Common SwiftUI Mistakes - and how to fix them!
HTML-код
- Опубликовано: 31 июл 2024
- SwiftUI is a big and complex framework, and although it’s great fun to work with there’s also a lot of scope for making mistakes. In this article I’m going to walk through 8 common mistakes SwiftUI learners make, and how to fix them.
1:48 - Adding views and modifiers where they aren't needed
4:05 - Using @ObservedObject when they mean @StateObject
6:38 - Putting modifiers in the wrong order
12:29 - Attaching property observers to property wrappers
16:20 - Stroking shapes when you mean to stroke their border
19:19 - Using alerts and sheets with optionals
22:36 - Trying to get "behind" their SwiftUI views
25:03 - Creating dynamic views with invalid ranges Наука
You are simply unbelievable. The amount of knowledge you give to developers is unmeasurable. Thanks a lot Mr. Hudson ♥️
One of the best teachers ! Knowledgable and great speaker.
1. Adding views and modifiers where they aren’t needed - 1:48
2. Using @ObservedObject when you mean @StateObject - 4:05
3. Putting modifiers in the wrong order - 6:38
4. Attaching property observers to property wrappers - 12:28
5. Stroking shapes when you should stroke borders - 16:19
6. Using alerts and sheets with optionals - 19:18
7. Trying to get “behind” your SwiftUI views - 22:36
8. Creating dynamic views using invalid ranges - 25:03
It’s really clear your main focus is teaching the community and it’s why you are an invaluable asset to any aspiring SwiftUI developer. You provide time stamps and a quick summary at the beginning easing the bug fixing process for all of us. Thank you so much, Paul, many thanks, from Oxford.
Paul, I will be forever grateful to you for the amount of knowledge you share and for being such a great teacher.
This video was awesome, Paul! Please do more of them.
This is by far the best explanation I’ve come across for @State. I’m very much a beginner to coding in general and began working with SwiftUI late last year until I got frustrated back in February and gave up on it. I picked back up with it in April and understanding that @state means the view owns the data makes that property wrapper so much clearer.
Incredibly informative and well paced. Thanks!
Amazingly clear, well-thought and useful video! Thank you soo much 🙏
Excellent video. This is exactly what is needed after one learns the basics and has tried writing some apps. Thank you.
Dear Paul Hudson, I really appreciate your dedication and would like to thank you for your contribution
Amazing video! It cleared the air with all the confusions. Thank you so very much!
I am a long time programmer that keeps coming back to your excellent videos. Good job!
You’re back!
Very very useful, made our perception of how they all work much better 👍🏻
Thanks for this. As a dev since the 80's, I must say SwiftUI has been one of the trickiest languages I've tried to learn. While crazy powerful, there's so much you need to know up front to make it work. You do a great job explaining things!
Excellent examples and best videos for study. TYVM, you do great lessons for us!
This channel and the website have been pivotal in my app development 🙌 thanks for the exceptional content.
This is how I know he's a great teacher. After he explains stuff, I always go "Of course, obviously."
Well that clears up loads of stuff for me Paul - thank you!
It’s a great day whenever a new Hacking with Swift video comes out! Each one gets me a little closer to wrapping my head around iOS development 🤯
This video and the idea behind it is great. would love to see more video like this. common / uncommon issues and what is the best way to handle them, for SwiftUI and Combine.
Yes, actually, Paul is doing the job that I had been expecting from Apple all these years… ;-)
Simply great - thanks, Paul!
That .alert was amazing option that I didn't know that!
Thanks Paul
Great work! Probably the best Teacher of swiftUi
This tips will make me remove so much useless repetitive code. Thanks so much!
Fabulous. Excellent content, clear and presented well. Thank you
Learnt a couple things. Thanks, man!
I love the idea of this video... Reminds me of Pareto 20/80 rule... So, for instance 80% of the problems come from 20% of your mistakes. Identifying those and removing them then leads to disproportionate gains... Very cool frame from which to improve the code, that I haven't seen anywhere else yet. Thanks for sharing
Very handy. Thanks Paul!
Very useful video, it will definitely save my debugging time around the codes 😃👍
extremely helpful. finally just found 2 errors in my code with your video. thanks a lot!
yes modifiers in the wrong order is annoying I wish they add a visual error or something for it. Thank you Paul
You are back on RUclips. Great
amazing as always
Last week i started with SwiftUI and i feel that is the best decision in a time. I have five partners to teach everything this in the future. Thanks!
Thanks for the video, Paul.
Great video, as usual :-) Thanks for the good advices! I hope, I can remember when I run into these problems :-)
Brilliant as always
Thanks Paul great video.
Awesome Content, Thanks Paul
Thank you Paul!
I learnt a lot, thank you!
Really cool, I almost finished a project written using SwiftUI, but still there is something new)
Very helpful! Thanks!
Totally awesome! Thanks
This video was awesome.
Pufff so much value! Thanks Paul, I was making a mistake on the second one 🤓
Cheers, Paul. Hopefully you'll do more content like this :D
Thanks great video
extremely helpful
You are helping me a log with hackingwithswift, thank you.
I'm still a little frustating with SwiftUI, hope that pass very soon with more learning.
Awesome!
Great video. I think I made all the 8 mistakes loll. Thank you so much.
Great video, deep explaining. Thanks a million.
I've been working my mind around something and have asked about it all over the place with no easy answer so far. I need to build a Text from an array of texts where each time a word is emphasised and should have an image right after, a clickable image that would bring up a meaning on the screen or so.
Problem is you cannot concatenate text with a button, or can you?
I don't know if you have the time to answer me, but thanks any way for your great videos.
thanks for explain @ObservedObject, and @StateObject, I would use it the other way round or get confused on which one. Maybe you can show next time how different the two function, so people get an detail view of what does what.
great video! There is one thing I wanted to ask!
I got the case where I got a SF Symbol and I attach a continuous animation to it like:
Animation.linear(duration: speed).repeatForever(autoreverses: false)
I get new speed values from my model in the view, but the animation is only changing if I restart the app. It does not update even I print the value of speed and indeed it does change, the animation keeps the original value of speed throughout. What I am doing wrong conceptually here I wonder?
Woah, I wanna cry. Thank you thank you for explaining @State and @Observed objects . I couldn’t understand why my fetchDat() networking request request and updates again and again every time I came back from navigation view. I was thinking that it’s because of I’m calling networking request in .onAppear()
Awesome content, thanks 2straws.
For the second common mistake, what do you do if you're developing SwiftUI with an iOS13 requirement?
Thanks
Paul, can you please make a video explaining the difference between components and views? I never know when to separate that in my projects. It ends becoming a huge view, full of modifiers.
Apple should hire you as the the CTO’s CTO.
Thanks Paul, you nailed it again, common error number 1 I did a lot with RoundedRectangle, where I only need a color. But one annotation: I think combining PropertyWrappers (like @Published) with Property Observers (like didSet ...) works fine since Xcode 12. Do you disagree?
Using @ObservedObject when you mean @StateObject - @ is a good catch
Hi Paul! I have a question for you that " Can we add modifiers for Image in tabItem in SwiftUI?"
Around 21:40 you show how to display an alert using `.alert` and the `item` argument instead of `isPresenting`. But that also uses the `Alert` view which is now deprecated. What is the new way to display and alert based on a binding to an optional value instead of a binding to a boolean?
This may be a stupid question, but since Swift is open source is there a way to see the code for .font and see the details @paulhudson is talking about?
Hi Paul.
I'm stuck with one question. Can you help me? "isEqual"method and operator "===" identical? Which one to use is a matter of taste or are there nuances?
Not understanding the state view was the biggest difficulty when first learning. Noting that regular variables could change, but by themselves, nothing visually would occur. Make sense of course now as you don't want to tax the system unless a state is changed, but when new to swift you learn things like that. For example, why doesn't the button's new set variable not show up in the text field... well you didn't change the view.
Do you have any tutorials on sound events in 14, I have been working with sound clips in my apps, but I feel like the way I am doing it is probably using too many resources and makes the app sluggish. Also trying to mix sounds instead of stopping one before starting the next seems tricky.
that thing where every new view modifier wraps view into another view - doesn’t it have negative impact on performance with more complex UIs ?
I’m currenrly thinkimg about approach for complex app which does a lot realtime audio processing (which is done in separate resltime audio thread using mostly plain C code thriugh ObjectiveC wrapper) - i am a bit afraid SwiftUI will have bad impact on performance… is SwiftUI viable to use also for more CPU extensive apps ??
Great! Thanks! =) What about the problem of a huge EnvironmentObject (many Published vars)? Also, what about navigation in complex project, when some screens could lead to several other screens & there are several UI flows in UX? What about design architectures: MVVM, MVI? What about Coordinator pattern for SwiftUI project with custom NavigationStack & container views (when we just switching some state & in switch block dynamically choosing which view to show)? =))))
Really nice what mac do you have to get these quick live views i always have to wait several seconds.
It's a maxed out 16-inch MacBook Pro.
what if you are targetting iOS 13 and don't have access to @StateObject?
Can you please do a video about how you came up with that binding code and explain the syntax as it’s confusing as hell. Swift is NOT easy to read or understand.
opt+cmd+[ or ] to move a line in Xcode 😉
Please provide tuorial about cognito ios authentication
But what to use instead of StateObject in iOS 13 where there wasn’t It and only ObservedObject. ObservedObject seems to be useless for me now
@ObservedObject still works just fine if your @ObservableObject is injected via the initializer for your view; and a strong reference to that object is held elsewhere. So in Paul's example, if he were to use `@ObservedObject var model: DataModel` as a property of `ContentView`, the data model instance could perhaps be created by whichever struct/class is creating `ContentView` (where it would be marked with @StateObject). The main benefit here is that it would allow you to use a single instance of `DataModel` in multiple views. Hope this helps. See here: gist.github.com/neilsmithdesign/ad9fc1a6f5856fdf79ce77a3ab4e3d5c
@@neiljsmith11 Yeah but If I cannot use @StateObject like in iOS 13, then I need to pass this reference to inits basically from AppDelegate
@@michaziobro5301 yes. If you’re supporting iOS 13 then pass by reference via initialiser would be a solution.
27:33 Line 16 , why have not self , you can run code ? I can't run code like you if have not self.:(
So in the case of something like id: \.self; what exactly is the backslash doing? Never quite got that. It's always just been one of those mystical tokens. - I mean, I guess it relates to what the bound of the following .self is, because it's not the encapsulating ContentView struct, but thee aforementioned values in the list, but in like a general abstract sense, what is the \, does it belong just to SwitftUI or is there a general Swift concept that it comes from?
Cheers
Great question! The backslash signals a Swift key path, and you can find out more about them here: www.hackingwithswift.com/example-code/language/what-are-keypaths
@@twostraws Thanks, Paul. Really appreciate it :)
@@twostraws If you squint it almost looks like a form of reflection, but I assume behind the scenes when compiled this just acts a bit like a pointer or something like that
Hello, Paul, thanks a lot! Without you, I would be entirely lost. As always, everything just in time ;-)
Still just wondering about this strange screen position (@11:17) of x: 150, y: 150…, I would have expected the x-position to be much more far off…
Is it, because it takes the middle of the "Hello, World!" string as the position?
See you ;-)
Yes, exactly. I wish this were optional!
This is brilliant, but what I really need to know is what the keyboard shortcut is to restart the canvas preview! Anyone?
Opt+Cmd+P.
@@twostraws You are a god amongst men.
23:43 yes you guess right 😅😅🤭
👍Have some Exta like🙂
This is beautiful, but your idea of "cross platform" is somehow distorted :D
First