I would say it's creating the opposite. Now while consuming external code (or nested/derived code), you have no way to know if the value is a $state or not. The typing whould only be a string, but it would actually be a proxy to a value.. I'm still a big fan of the runes tho !
I use react at work, but your videos + svelte's runes introduction (fantasy nerd here) made me delve into svelte whenever I have some spare time. kidas brate!
Amazing video as always! I really love your content. I've noticed there isn't a good video explaining all the i18n options for sveltekit available and comparing them. It could be a good idea for a future video and I'm sure that your audience would be very interested to it.
Currently rewriting a mess of a nextjs project in sveltekit. Im using svelte 4 because rich said svelte 5 is not yet ready for production but man does svelte 5 seem like a MAJOR upgrade from svelte 4. excited to see when is comes out officially to start migrating!
I love your content, I am about to start getting into Svelte and am super excited, this looks so much easier than other frameworks. You should start exporting in 4k. Even if you recorded in 1080 it increases the bitrate and makes it look much better. Your videos are beautiful they deserve max bitrate
Little confusing at 9:10. I tried `console.log`ing `counter.count` after each `counter.count` expression at the end of the script, and it does show it updates to 1 (i.e. it doesn't stay 0). Looking at the compiled output in the Svelte playground, the behavior I get is due to it being non-proxied state, i.e. "raw" state, if it were actually referenced in the scope it's declared. But since it's not referenced, the compiler is "smart" enough to compile it as a plain JS object. Alternatively, if you were to create the count with `let counter = $state({ count: 0 })` you get entirely different issues since you're dealing with state proxies. You get back a plain NOT proxied object from `createCounter` but the `count` property itself is proxied; any assignment to `counter.count` then essentially assigns the proxy away making it a different reference - in this case to a number value. All very confusing, but certainly why you shouldn't be doing it that way...
"Svelte's runes are giving me serious MobX vibes! The computed values, reactions, and tools like when and trace feel so familiar. I am big fan of a mobx , now svelte too
Looks like MVC is back on the menu boys! Having written a diagram app using Svelte 3 and interactive components derived from class states, Runes look like a dream come true.
i love svelte, i am always afraid to dedicate myself to learn it fully because i feel i can't get a job with it, but i really enjoy so much developing in svelte.
@@JoyofCodeDev Oh, sovereign joy of code, no matter how metaphorical or cheesy it may seem, I was waiting with the greatest subtlety for any response from you, and since you have heard this sentence, I must enjoy coding what I love. Furthermore, if UX and UI are for the user, from now on I proclaim DX & DI: Developer Experience & Developer Interface :) however, thanks a lot
Great overview. I've spent a lot of hours on svelte and am quite comfortable with the quirks of the current version. I find it more kinda hard to wrap my head around what magic happens with $state. Especially the props thing doesn't seem super intuitive. I'm sure I'll get used to it but saying it's "easier" or clearer kinda feels like a lie.
I think `let count = 0` is more magic than `let count = $state(0)` which works the same inside and outside Svelte components - what makes Svelte special isn't `let count = 0` but `=` for reactive assignments.
Any issue with runes and form submission? On initial load I initialize form fields to the last record added, except one "index" field which is incremented by 1 - Its a read only field. Works fine on initial form load. I can change field value and using state, derived, effect everything works fine. When I submit, record gets saved fine but then the form fields will not reinitialize as when component first loaded,/ Instead fields values default as if I have no records despite setting them correctly. Worked fine with SK4 reactives. Any thoughts? (@ 11.56 on:keydown )
I am just waiting for melt-ui to be runified. It would be a pain to start coding with its stores paradigm and then change to runes. The refactoring required is akin to rewriting the client code from scratch.
Please is there like a PDF document that one can learn about svelte 5 ... i really loved Real-World Svelte: Supercharge your apps with Svelte 4 by mastering advanced web development concepts By Tan Li Hau cant we have something like that for svelte 5
@@francoisbouchet9907I’ve found that having side effects similar to subscribing to a store is a bit rough (outside of svelte components). Runes don’t really replace stores imo.
@@francoisbouchet9907 Sveltekit 5 supports stores and even introduces local stores with .svelte.js extension. I am running SK5 Runes mode with local and global stores. No rewrites needed except local need that extension.
@@JoyofCodeDev its very sad. Really good video otherwise. Im guessing its because of the dark nature of the video. These compression strategies usually compress many dark values together because its more difficult to distinguish between them. Next time i would recommend you upload in a higher resolution like 4k or use 30fps instead of 60
Before I learned Svelte, I used React, then SolidJS. When I learned Svelte 3, in my opinion, it was simpler and it was the best language and framework. In my opinion, Runes will destroy this framework, something that was simple now start going to React again. The only difference between SolidJS and Svelte now is where you have XML and where JS.
svelte is for lazy people like me who dont wanna dive into overcomplicated react bullshit and its stupidass ecosystem. if i have to use this effect and state fake ass react shit, i will use react directly
Svelte 5 == Almost Solid.js but with $ prepended so they can continue to implement a compiler and experiment with abstractions instead of finding elegant ways to do simpler functional programming. In my opinion Solid.js is superior, simpler, more elegant, not because it adds terser syntax or more bells and whistles, but simply because it achieves the same things using just the programming language itself and well design, and just the right amount of, abstractions. It's also my opinion that learning the language itself is the biggest problem in the JS FE world. No offence but too many people learn JS by learning React first or some other framework, because that's what they want to do at work, but that's not what being a good programmer is. /endrant
Nope. Solid doesnt reach what Svelte can reach. Solid is just react with signals. Svelte is quite different, in the big picture it shows how simplicity at its finest can improve your day to day.
I like abstractions. I'm not a hardcore developer, just a hobbyist, so having some opinionated magic is great. No disrespect to solid, is a great framework, but it didn't clicked for me although it was on top of my list. To be honest, if not for some great svelte edutainers I would be using solid, or maybe vue.
I think you misunderstood completely how Svelte3/4 worked and how Svelte 5 it does. Just because Svelte5 is using Signals ( like Vue ) you think that is almost Solid. This is like the people who thinks that Svelte5 looks like React because has $effect(). Please, try to learn and read deeper: devs are responsible at some point about companies decisions in the future regarding tech stack to use.
If you don't use these libraries with your side-project as they would make your development easy, don't ever use them. They are dead for professiononal web development and you wouldn't learn anything about anything because you'd take everything as granted, React is popular because you do everything, it's plain javascript that poops html, thats it
I hope I'm misunderstanding your sense of humor, but I personally prefer my development to be easy rather than hard. As for not learning anything, how is that possible? After all, "these libraries" are open-source, and the code is there to be examined and learned from. And furthermore, I truly believe you need to learn, and learn well, how to use them despite their (apparent) simplicity.
@@paolo-e-basta yes, a javascript junior developer would go through source codes. React is not hard, nor Next, they are tools to make something work, if this something is too much for your project, of course don't use it, but then don't talk about it either.
@@ddddddkkkaSvelte is also a “[tool] to make something work.” So what’s your point? Ironically, the layout of svelte is closer to vanilla html/js/css than something like react/jsx; if anything, a beginner learning svelte will learn more about vanilla html/js/css vs one learning react.
@@JJCUBER React is not there to make you learn html, I was talking about normal people who are not 5 years old and jump to a framework without knowing basic concepts of frontend. You too know that frameworks like Vue and Svelte is out there because PHP developers didn't want to learn frontend, these are frameworks that gives everything out-of-box and can make basic projects that are mostly/strictly bound to some backend. Not so great for a student that wants to know how a real application should work and the inner concepts of a frontend system, they are great if you want "magic" with a one click though.
Thanks for watching! You can support my work on Patreon or with a TH-cam channel membership. ❤
why are you whispering? you're eating your own words
Im actually glad svelte is introducing runes,cause its kind of made it difficult to get which variable is reactive or not,the progress is worthwhile 💯
I would say it's creating the opposite. Now while consuming external code (or nested/derived code), you have no way to know if the value is a $state or not. The typing whould only be a string, but it would actually be a proxy to a value..
I'm still a big fan of the runes tho !
Love the Svecosystem plug 🔌 great video man!
hello sir decaprio!
thank you! 😄
@@JoyofCodeDev not you it was huntbyte he actually lookalike 🤣🤣
The best and most comprehensive overview of reactivity in svelte as of now. Good job and thank you!
This is much clearer than the official documentation.
the preview docs for Svelte 5 are temporary and there's going to be official documentation and the tutorial when it's released
the official documentation is shit, that is why I am here.
The code in this video is literally copied from the official documentation lol.
Great production quality! Thanks for leading the Svelte 5 transition!
I use react at work, but your videos + svelte's runes introduction (fantasy nerd here) made me delve into svelte whenever I have some spare time. kidas brate!
From the intro, you can perceive this video is going to be especial
Amazing video as always! I really love your content.
I've noticed there isn't a good video explaining all the i18n options for sveltekit available and comparing them. It could be a good idea for a future video and I'm sure that your audience would be very interested to it.
Amazing explanation video.
It makes a svelte version upgrade much easier with all of these examples!
Thank you 🙏
Currently rewriting a mess of a nextjs project in sveltekit. Im using svelte 4 because rich said svelte 5 is not yet ready for production but man does svelte 5 seem like a MAJOR upgrade from svelte 4. excited to see when is comes out officially to start migrating!
Svelte is getting every day even better, thank you for such great content!
Thanks!
thank you! 🙏
I'm so excited for Svelte 5 😍.
I love your content, I am about to start getting into Svelte and am super excited, this looks so much easier than other frameworks.
You should start exporting in 4k. Even if you recorded in 1080 it increases the bitrate and makes it look much better. Your videos are beautiful they deserve max bitrate
I might try it out
It is a great video, clear and good
comparing examples. And the slide change animation is also top.
Svelte 5 is really exciting, hopefully it launches soon!
Little confusing at 9:10. I tried `console.log`ing `counter.count` after each `counter.count` expression at the end of the script, and it does show it updates to 1 (i.e. it doesn't stay 0).
Looking at the compiled output in the Svelte playground, the behavior I get is due to it being non-proxied state, i.e. "raw" state, if it were actually referenced in the scope it's declared. But since it's not referenced, the compiler is "smart" enough to compile it as a plain JS object.
Alternatively, if you were to create the count with `let counter = $state({ count: 0 })` you get entirely different issues since you're dealing with state proxies. You get back a plain NOT proxied object from `createCounter` but the `count` property itself is proxied; any assignment to `counter.count` then essentially assigns the proxy away making it a different reference - in this case to a number value.
All very confusing, but certainly why you shouldn't be doing it that way...
Showing the generated code was dope. Well done
"Svelte's runes are giving me serious MobX vibes! The computed values, reactions, and tools like when and trace feel so familiar. I am big fan of a mobx , now svelte too
I never used it but the creator of SolidJS is a fan of MobX and made signals popular which inspired many frameworks
Awesome video, thank you!
How beautiful is that my friend. I'll remember always you from that 😀
Looks like MVC is back on the menu boys! Having written a diagram app using Svelte 3 and interactive components derived from class states, Runes look like a dream come true.
Good explanations, subscribed
You're amazing, the best svelte advocate
Thank you!
Love your materials, they are contains a very useful information, thank you 👍
Great video man 🤙
i love svelte, i am always afraid to dedicate myself to learn it fully because i feel i can't get a job with it, but i really enjoy so much developing in svelte.
listen to your heart
@@JoyofCodeDev Oh, sovereign joy of code, no matter how metaphorical or cheesy it may seem, I was waiting with the greatest subtlety for any response from you, and since you have heard this sentence, I must enjoy coding what I love. Furthermore, if UX and UI are for the user, from now on I proclaim DX & DI: Developer Experience & Developer Interface :)
however, thanks a lot
Great overview. I've spent a lot of hours on svelte and am quite comfortable with the quirks of the current version. I find it more kinda hard to wrap my head around what magic happens with $state. Especially the props thing doesn't seem super intuitive. I'm sure I'll get used to it but saying it's "easier" or clearer kinda feels like a lie.
I think `let count = 0` is more magic than `let count = $state(0)` which works the same inside and outside Svelte components - what makes Svelte special isn't `let count = 0` but `=` for reactive assignments.
@@JoyofCodeDev "I think `let count = 0` is more magic than `let count = $state(0)`" Really? Ask someone who sees this for the first time.
May I ask what program did you use to animate this video? The way you showcase code examples is really smooth :)
I use Animotion which I made
A video on when to use stores and when to use runes please :D
you should only use runes because they replace stores
@@JoyofCodeDev But stores + RxJs are kinda nice :(
This was great, thank you!
Any issue with runes and form submission? On initial load I initialize form fields to the last record added, except one "index" field which is incremented by 1 - Its a read only field. Works fine on initial form load. I can change field value and using state, derived, effect everything works fine. When I submit, record gets saved fine but then the form fields will not reinitialize as when component first loaded,/ Instead fields values default as if I have no records despite setting them correctly. Worked fine with SK4 reactives. Any thoughts? (@ 11.56 on:keydown )
Hi, I have a question. Could I use a svelte store value, eg. $name, inside a svelte form action?
Seems like Svelte 5 finally providers what Svelte 3 promised. :)
I am just waiting for melt-ui to be runified. It would be a pain to start coding with its stores paradigm and then change to runes. The refactoring required is akin to rewriting the client code from scratch.
Please is there like a PDF document that one can learn about svelte 5 ... i really loved Real-World Svelte: Supercharge your apps with Svelte 4 by mastering advanced web development concepts
By
Tan Li Hau cant we have something like that for svelte 5
I am confuse. What happen to stores in Svelte5?
I have a store and could not figure out how to refactor to used Svelte5
stores are deprecated. you can just declare a variable as a state rune and pass it as a prop everywhere needed
@@francoisbouchet9907 Stores are not deprecated, they will work exactly like in Svelte 3 & 4. But in most scenarios they can be rewritten to signals.
@@francoisbouchet9907I’ve found that having side effects similar to subscribing to a store is a bit rough (outside of svelte components). Runes don’t really replace stores imo.
@@francoisbouchet9907 Sveltekit 5 supports stores and even introduces local stores with .svelte.js extension. I am running SK5 Runes mode with local and global stores. No rewrites needed except local need that extension.
Good explanation.
amazing video!
Great video, you are awesome !
How do you make these code snippets transition ? Which tools are you using to make your videos ?
I use Animotion which is something I made and I'm working on the video for it next
I missed you my friend :)
i smell svelte 5 is near !!!
88% complete
@@すべてに興味を失う Not exactly.
@@mohabedr5030it is, go check their GitHubilestones
@@mohabedr5030 why not?
14:29 is perfect
I am somewhat concerned about using typescript on my svelte 5 project. Is it any better for bigger projects or just pure coding overhead?
typescript is useful on any project
svelte 5 is not yet official in sveltekit 2 right? still have a lot of time to practice runes
you can pick Svelte 5 from the options and it's backwards compatible so it's easy to transition
Lmao I fucking lost it at 14:30 😂 nice video!
What a beauty.
subbed!
Why is the compression so blocky and ugly? Even at 1080p
TH-cam compression works in mysterious ways
@@JoyofCodeDev its very sad. Really good video otherwise. Im guessing its because of the dark nature of the video. These compression strategies usually compress many dark values together because its more difficult to distinguish between them. Next time i would recommend you upload in a higher resolution like 4k or use 30fps instead of 60
it just takes time 😄
Great vid, now we need Material UI for svelte, not the trash its out there (outdated)(non-svelte5)
Before I learned Svelte, I used React, then SolidJS. When I learned Svelte 3, in my opinion, it was simpler and it was the best language and framework.
In my opinion, Runes will destroy this framework, something that was simple now start going to React again. The only difference between SolidJS and Svelte now is where you have XML and where JS.
Svelte optimizes for vibes
great
So svelte discovered redux? 😅
I think you're lost
@@JoyofCodeDev no worries, everone has some skill issues
14:29 Jananisu
Svelte 5 is awesome, but if you're using any external Svelte libraries in your project, WAIT until it's fully supported before updating. Trust me 😭
Yea, it's a major version update, we shouldn't just update older version to new...
make your own library 🧠
@@JoyofCodeDev can you make a video about making svelte 5 libs ?
so its basically vuejs now?
I would say Vue is trying to be more like Svelte if you look at Vue Vapor
@@JoyofCodeDev mithril was where its at.. they should have developed more in that direction
This is not a guide for Beginners, this is a guide for people that already know Svelte and want to move to 5.
thanks, I fixed it
@@JoyofCodeDev Good, thank you, now I wish you release a video or series of videos for real beginners, like me.
I plan to
@@JoyofCodeDev thank you
14:29 lmao
Was completely thrown off by the waifu voice 😂😂😂😂
Sverte bicom riacto , badto chenshi 14:29 🤣🤣🤣🤣
svelte is for lazy people like me who dont wanna dive into overcomplicated react bullshit and its stupidass ecosystem. if i have to use this effect and state fake ass react shit, i will use react directly
the code too small
🤔 at this point, anyone can be frontend dev in a week...
why in svelte 5 using two method, on: and onclick,.... Not simple, so complicated, svelte becoming sh*t
you can use both because Svelte 5 is backwards compatible making it easy to transition but it's going to be deprecated in a future version
why are you whispering?
Svelte 5 == Almost Solid.js but with $ prepended so they can continue to implement a compiler and experiment with abstractions instead of finding elegant ways to do simpler functional programming.
In my opinion Solid.js is superior, simpler, more elegant, not because it adds terser syntax or more bells and whistles, but simply because it achieves the same things using just the programming language itself and well design, and just the right amount of, abstractions.
It's also my opinion that learning the language itself is the biggest problem in the JS FE world. No offence but too many people learn JS by learning React first or some other framework, because that's what they want to do at work, but that's not what being a good programmer is. /endrant
Nope. Solid doesnt reach what Svelte can reach. Solid is just react with signals.
Svelte is quite different, in the big picture it shows how simplicity at its finest can improve your day to day.
I like abstractions. I'm not a hardcore developer, just a hobbyist, so having some opinionated magic is great. No disrespect to solid, is a great framework, but it didn't clicked for me although it was on top of my list. To be honest, if not for some great svelte edutainers I would be using solid, or maybe vue.
I think you misunderstood completely how Svelte3/4 worked and how Svelte 5 it does. Just because Svelte5 is using Signals ( like Vue ) you think that is almost Solid. This is like the people who thinks that Svelte5 looks like React because has $effect(). Please, try to learn and read deeper: devs are responsible at some point about companies decisions in the future regarding tech stack to use.
@@SRG-Learn-Code you're not a real developer until you learn to have a love-hate relationship with abstractions.
Too many gotchas with the API == React.
ignorance is bliss
If you don't use these libraries with your side-project as they would make your development easy, don't ever use them. They are dead for professiononal web development and you wouldn't learn anything about anything because you'd take everything as granted, React is popular because you do everything, it's plain javascript that poops html, thats it
I hope I'm misunderstanding your sense of humor, but I personally prefer my development to be easy rather than hard. As for not learning anything, how is that possible? After all, "these libraries" are open-source, and the code is there to be examined and learned from. And furthermore, I truly believe you need to learn, and learn well, how to use them despite their (apparent) simplicity.
@@paolo-e-basta yes, a javascript junior developer would go through source codes. React is not hard, nor Next, they are tools to make something work, if this something is too much for your project, of course don't use it, but then don't talk about it either.
@@ddddddkkkaSvelte is also a “[tool] to make something work.” So what’s your point? Ironically, the layout of svelte is closer to vanilla html/js/css than something like react/jsx; if anything, a beginner learning svelte will learn more about vanilla html/js/css vs one learning react.
@@JJCUBER React is not there to make you learn html, I was talking about normal people who are not 5 years old and jump to a framework without knowing basic concepts of frontend. You too know that frameworks like Vue and Svelte is out there because PHP developers didn't want to learn frontend, these are frameworks that gives everything out-of-box and can make basic projects that are mostly/strictly bound to some backend. Not so great for a student that wants to know how a real application should work and the inner concepts of a frontend system, they are great if you want "magic" with a one click though.