Build A Rust Frontend (Really FAST Web Apps with Yew)

แชร์
ฝัง
  • เผยแพร่เมื่อ 26 ก.ย. 2024

ความคิดเห็น • 454

  • @codetothemoon
    @codetothemoon  ปีที่แล้ว +46

    ERRATA
    There is a mistake in the video where there is a missing parenthesis, the corrected code can be found here github.com/Me163/youtube/tree/main/RustFrontEnd

  • @dr-maybe
    @dr-maybe 2 ปีที่แล้ว +359

    Cool video, but it might be better with a “limitations” section. Accessing the DOM, window or document is a real hassle, the rust GUI browser frameworks are not mature and the performance isn’t actually better than JS in these frameworks. I’m a huge rust fan, but wouldn’t recommend yew over react for serious projects yet.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +93

      Totally - I probably should have expanded more on this in the video. Rust on the frontend is still bleeding edge, and it's still not 100% clear that WASM DOM manipulation will get faster than JS DOM manipulation. But if the application's performance bottlenecks exist outside of DOM manipulation, it probably makes sense to at least consider Rust.

    • @climatechangedoesntbargain9140
      @climatechangedoesntbargain9140 2 ปีที่แล้ว +3

      Sycamore is faster than most JS frameworks!

    • @liranpiade4499
      @liranpiade4499 2 ปีที่แล้ว +25

      @@codetothemoon It should be way faster once wasm gets native dom manipulation capabilities as opposed to having to call javascript.

    • @yashsaxena9
      @yashsaxena9 2 ปีที่แล้ว +2

      Is there any rust library/framework for gui development, not really limited to dom and web, but gui in general, like for desktpp apps, I just want to use rust and use its fastness, security and multithreading and make a blazingly fast and solid app!!

    • @yashsaxena9
      @yashsaxena9 2 ปีที่แล้ว

      @@climatechangedoesntbargain9140 for linux and mac? Are there anything? I don't really care about windows. Also of there are, are they permant enough conpared to other methods of creating softwares...???

  • @t0prar
    @t0prar 2 ปีที่แล้ว +69

    I'm a systems developer and I love rust for that purpose.
    But what I love even more is to see how this basically helps with applications that usually rely on Python, Ruby, JavaScript and so on.
    Although mostly not yet production ready for all of this. This really is a hell of a language. Can't wait for all these crates to mature.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +7

      Totally agree! I think it is often pigeonholed as a "systems language" and prematurely ruled out for other use cases like web frontends or REST services.

    • @schizoidman9459
      @schizoidman9459 2 ปีที่แล้ว +2

      @t0prar: Agree, but using Rust only to interface with HTML and CSS is so ridiculous that it really doesn't make it shine for its real value. This is completely archaic and Neanderthal reasoning. This is a typical video from someone coming from "stack" programming and "front-end" JS cavemen mentality. Sorry, but using Rust for system development has absolutely NOTHING to do with this junk, and you know it. There is no room here for any praise, just to lament that people are still not seeing the light. Please don't encourage them to stay in the caves and to "seduce" women by hitting their head with wooden bats.

    • @aneeshprasobhan
      @aneeshprasobhan ปีที่แล้ว

      @@schizoidman9459 username checks out

  • @Hobbitstomper
    @Hobbitstomper 2 ปีที่แล้ว +64

    From what I understand, WASM doesn't have access to the HTML DOM and anything that wants to access the DOM, has to do so via WASM DOM API which uses JavaScript. The official Yew docs mention that "using DOM APIs from WebAssembly is still slower than calling them directly from JavaScript". This is something that they are hoping to fix in the future, so that WASM has direct access to the DOM. So for now it seems, anything that accesses the HTML DOM is being compiled into JavaScript. The only performance gain we get is the server side execution of front end functions. Anyone, feel free to correct me, as I am only 99% sure.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +24

      I believe your first 3 sentences are correct. Re: "The only performance gain we get is the server side execution of front end functions." - WASM does still run in the browser (it can run on the server too, but thats a separate video), and will be more performant than JavaScript for pretty much anything outside of DOM manipulation and network IO. Those two things are the most common bottlenecks for webapps, but for those where they are not, WASM may provide significant benefit.

    • @nomiscph
      @nomiscph ปีที่แล้ว +1

      But in the end the perf gains from network is not really existing, and having DOM access is a stale issue for one reason security so i Think its very unlikely it Will ever have it - but time Will tell

    • @nomiscph
      @nomiscph ปีที่แล้ว

      I Think it was @Theprimeagen that made a video, where he talked about a startup that built a webapp in rust only to gain 15% perf on top of react; compaired to how much harder it is to find developers and how much time it takes to code i dont Think there is a business case.
      I Think wasm should only serve as a foreign function kinda implementation.
      I believe that wasm have a place but js and web tech another

    • @nomiscph
      @nomiscph ปีที่แล้ว +2

      Just to add, ofc if you wanna make graphic heavy application near native wasm might be it, or it could be webgpu which is behind a flag in chromium

    • @Hobbitstomper
      @Hobbitstomper ปีที่แล้ว +2

      @@nomiscph I think in the end everything is possible, it all comes down to how WebAssembly is able to create new standards that are then hopefully implemented by all major browsers. If all parties involved in the development of WASM and browsers work together, they should be able to pull things off that we can only dream of.

  • @boi64pr60
    @boi64pr60 2 ปีที่แล้ว +46

    I've been waiting for a video tutorial like this, thank you.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +3

      Glad it was helpful! It makes me happy to see that others are also looking for JS alternatives!

    • @Kevin-jc1fx
      @Kevin-jc1fx 2 ปีที่แล้ว

      @@ccriztoff What do you mean exactly?

    • @Kevin-jc1fx
      @Kevin-jc1fx 2 ปีที่แล้ว

      @@ccriztoff You can simply clarify what you mean.

    • @Kevin-jc1fx
      @Kevin-jc1fx 2 ปีที่แล้ว +1

      @@ccriztoff Dude, where did you see any obligation? I didn't understand what you meant so I simply asked you to clarify, that's all. Of course, you are free not to. I just assume that if you take the time to comment, it means you want to say something. If you wanted to keep it to yourself, you could just watch with no interaction.

  • @MeizanoAM
    @MeizanoAM 2 ปีที่แล้ว +30

    Your content is really great. The expertise on rust is on point. And no time is wasted.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +6

      Thank you Meizano! I strive to pack in as much value per second of watchtime as possible

  • @kg3217
    @kg3217 2 ปีที่แล้ว +6

    Really liked how it was quick and shows enough similarity with react, so easier to try it

  • @emilcrafter
    @emilcrafter 2 ปีที่แล้ว +31

    This is really cool and all, didn't expect to see a "react equivalent" in Rust. I'm betting we'll see much more like this in the future. HOWEVER, if I were to ever use wasm on a project, you best believe that project has to be something I'm so passionate I'm willing to die for it because no one in the world is going to want to maintain that code for me.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +4

      Glad you liked it! I can't speak to the maintainability of the code in the context of a larger project yet, going to try it soon and see how it goes...

    • @johnjallen
      @johnjallen ปีที่แล้ว

      Except the 5% of developers that love rust.

    • @nahiyanalamgir7056
      @nahiyanalamgir7056 ปีที่แล้ว +1

      @ivanpetrov2435 That's 99% of all web frameworks (frontend or backend).

    • @schmoris
      @schmoris 11 หลายเดือนก่อน

      Macromedia ColdFusion did quite a good job tho.

    • @nahiyanalamgir7056
      @nahiyanalamgir7056 11 หลายเดือนก่อน

      ​@@schmoris True but it had the disadvantage that you need a specialized software for development.

  • @santiagop.a1432
    @santiagop.a1432 2 ปีที่แล้ว +11

    This caught my attention immediately as I scrolled down my TH-cam news feed. I’m react dev and I feel like it’d be a good strategy to keep an eye on these new players in the web landscape. Rust feels weird though, but willing to shift if needed, as for now I’ll keep writing js code. Thanks, really insightful video.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +4

      Really glad you liked it! Compile-to-JS definitely remains the industry standard for now, but I'm with you in that it makes sense to explore outside the box and try to get a feel for where the industry might go in the future.

  • @anotidaisheneilmisi904
    @anotidaisheneilmisi904 2 ปีที่แล้ว +8

    First 40 seconds in and I'm impressed, great channel. Love the graphics and this is one of the few times I get to watch something that no one else is talking about, I know WASM and Rust obviously but I'd never heard of Yew

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Thank you and I'm so happy you got something out of the video! I'm obsessed with getting ahead of industry trends and addressing the areas for which there isn't much content yet.

    • @anotidaisheneilmisi904
      @anotidaisheneilmisi904 2 ปีที่แล้ว +2

      @@codetothemoon now you can say you have fans as far away as Zimbabwe

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +2

      @@anotidaisheneilmisi904 that's incredible!! great to have you onboard. this is what I love about the TH-cam platform!

  • @joshuaalan7580
    @joshuaalan7580 2 ปีที่แล้ว +5

    As a React diehard who's rapidly becoming a Rust lover (not that these are mutually exclusive), this blew my mind.
    Thank you for showing how simple yet powerful Yew can be!

  • @danygagnon8446
    @danygagnon8446 ปีที่แล้ว +2

    Okay this intro is beyond amazing. Nice video. Only thing with yew is the lack of community made components.

    • @codetothemoon
      @codetothemoon  ปีที่แล้ว +1

      thank you! yeah lack of community made components is definitely an issue in general in the Rust frontend ecosystem. I'm hoping the better these Rust frameworks make the developer experience, the more folks come onboard and subsequently the more community made components we will have. Right now the Leptos framework is turning heads, hopefully that will bring in a new wave of developers 😎

  • @emrecaniklioglu8682
    @emrecaniklioglu8682 2 ปีที่แล้ว +8

    Really great tutorial, I have been trying to learn Rust for a while now. And these kinds of tutorials were just what I needed to advance to the next step. I really appreciate it thanks a lot :)

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +2

      Awesome to hear! My goal is always to provide as much value as possible, so I love hearing that it's helped you! More to come!

  • @MunshiWahid
    @MunshiWahid 2 ปีที่แล้ว +4

    Great video. I wanna especially thank you for the font size. Thank you.

  • @BG-fo4si
    @BG-fo4si 2 ปีที่แล้ว +4

    Really good tuto. I'd love to see more of these in the future, as I am currently working on react and I feel like Rust has a potential to take over the web in some time in the future.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +3

      Thank you! Definitely more to come. I agree about the potential for Rust to become more popular for web development - i think WASM in general is going to disrupt web development far more than some folks realize.

  • @yt-sh
    @yt-sh 2 ปีที่แล้ว +1

    This was pretty cool, you explained all the necessary details while keeping the video short.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Thanks, glad you liked it!

  • @glennmiller394
    @glennmiller394 2 ปีที่แล้ว +1

    I've watched several of your videos on the way to learning Rust. Beneficial stuff!

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      so happy you found them valuable! what have been the biggest pain points for you so far in learning Rust?

  • @shimadabr
    @shimadabr 2 ปีที่แล้ว +1

    For a systems development language, that seems very straightforward. Hope to see future progress in this.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      I agree, and I also hope to see this ecosystem mature a bit. Biggest problem currently seems to be WASM bundle size, which can be in the megabytes for even the smallest apps...

  • @BbB-vr9uh
    @BbB-vr9uh ปีที่แล้ว +1

    Awesome, simple tutorial. Will definitely need to check out more example Yew projects on your channel.

    • @codetothemoon
      @codetothemoon  ปีที่แล้ว

      thanks, glad you found it valuable. If you're considering Yew for a project, maybe also consider Leptos - so far I'm a big fan after testing it out a little bit.

  • @JacoblBroughton
    @JacoblBroughton 2 ปีที่แล้ว +57

    Pretty intrigued, i’m a react dev but i’m very open to shifts in the web landscape. Last thing i’d want is to be left behind.
    After playing the DOOM port that was compiled to web assembly and served on the browser, i realized that this wasm thing might something to pay attention to.
    I’ve always written javascript, never really branched out much, so the Rust syntax looks pretty weird but there are also some similarities.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +11

      Nice! Yeah React/TS definitely has a strong foothold on the industry right now, but it's not completely inconceivable that Rust frameworks start to gain more traction soon.
      Re: DOOM port in the browser, this wasn't on my radar, I'm going to give it a try!

    • @rumplstiltztinkerstein
      @rumplstiltztinkerstein 2 ปีที่แล้ว +3

      Some of the similarities can be dangerous. One of them is that the "let" statement associates a pattern on the left to a pattern on the right. It looks the same to js, but it's actually more powerful. Rust compiler also wants to do every statically. So several algorithms that work in js needs to be adapted for rust.
      To summarize. In javascript, if all the lines are valid operations, it will not cause any errors until you get them at runtime. In rust, the compiler wants to know exactly when memory is allocated, how it is shared, and when it is freed. If there is the possibility of a race or memory leak to happen, it will generate an error at compile. We can use unsafe blocks for these situations if it is absolutely needed though.
      But on the bright side. The time spent debugging rust code is a small fraction of the time spent debugging js.

    • @jdrab
      @jdrab 2 ปีที่แล้ว +3

      Rust syntax is IMHO the weirdest of mainstream,production-ready languages. I am writing this as someone who loves perl. :D

    • @ed_iz_ed
      @ed_iz_ed 2 ปีที่แล้ว +1

      @@jdrab theres no way you think rust syntax is weirder than perl 😂 only really weird addition to common patterns is lifetime annotations

  • @IsThatNiek
    @IsThatNiek 2 ปีที่แล้ว +2

    Wow! You create some high quality content. Keep going and you're going to blow up!

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Thank you for the kind words. I really enjoy creating these videos, even more so when I see comments like this!

  • @nemeziz_prime
    @nemeziz_prime 2 ปีที่แล้ว +1

    I don't know much about Web Assembly or Rust, but this tutorial was really cool ! Didn't know we could do something like this without JS 😲

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Thanks, glad you liked it!

  • @chrisjudge705
    @chrisjudge705 2 ปีที่แล้ว +1

    Very concise and full working WebApp....great....Yeehaa
    1000 TXs for your video
    Best wishes from Berlin

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      1000 thx for watching, thanks Chris! Love Berlin, I can't wait to go back!

  • @ruijieyu9035
    @ruijieyu9035 2 ปีที่แล้ว +3

    5:56 Never heard of “French braces” before and couldn’t find anything about it. I usually just call them something like curly brackets

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +2

      Yeah somebody pointed this out, it's quite embarrassing. I had been calling them french braces for many years I think because I had a college professor that did so and it stuck. A quick Google search revealed that the correct term is curly braces, lol

  • @anthonypetruzzi158
    @anthonypetruzzi158 2 ปีที่แล้ว +2

    It's not just 30 something line of code. It's code plus a whole convoluted ecosystem of tools to create a simple web app. And I'm not just bashing Yew, the entire front end ecosystem can become really convoluted very quickly. This is why I really believe a good engineer knows what to use for the job at hand. For instance, something this simple, you can do completely with either vanilla js or jQuery. I'm sure Yew has this place in the web development world but I'm not going to use it for something this simple. I still think the greatest example of showing the power of a framework and how it can incrementally be used to create a wonderful application is the rails 7.0 demonstration that dhh does. If you haven't seen that yet you should really check it out.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +2

      If the end goal was to create this app, I agree Yew (or really any frontend framework) would not be a good choice. It's presented here merely as an exercise for those new to Yew. I'll definitely check out the Rails 7.0 demo you mentioned, thanks for the recommendation!

  • @DarkOceanShark
    @DarkOceanShark 2 ปีที่แล้ว +2

    Great tutorial sir! Thumbnail made me believe it's a new Fireship video XD

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Thank you and thanks for watching! That's a huge compliment to me, Fireship is one of my primary sources of inspiration! You can't quite see it, but I'm actually wearing a Fireship shirt in this video...

  • @TozzaYT
    @TozzaYT ปีที่แล้ว +1

    these sound effects are insane 🔥

    • @codetothemoon
      @codetothemoon  ปีที่แล้ว

      Thanks, some might say I went overboard :)

  • @greglocker2124
    @greglocker2124 2 ปีที่แล้ว +3

    This is convincing. I'm being drawn into the Rust cult. I was just starting Go, but it seems Rust is a better home for me. As a JS exile, I miss having an ultimate multi tool with an overly zealous userbase. I just can't deal with the slowness any more.

    • @recursion.
      @recursion. 2 ปีที่แล้ว +1

      Are you saying js is slow? how? like what can't you do in js that rust can? newb here, just trying to understand and tia

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Thanks, glad you liked it. The smaller Rust userbase is definitely a downside, but if I had to bet, I'd wager that it will grow substantially in the next 5-10 years. Personally I consider it inevitable that it overtakes C/C++ at some point.

    • @greglocker2124
      @greglocker2124 2 ปีที่แล้ว

      @@recursion. sorry I missed your response. I'll explain.
      I'm building an undetectable bot network that plays garbage mobile games. If you've ever seen those obscenely bad mobile games like Raid Shadow Legends or Mafia City and wondered, "who would actually play that???" the answer is that 99% of the players are bots. Don't even ask me how the game companies make money off of spending billions on getting users via paid bots. All I care about is not being poor anymore lol
      That being explained, my problem is this: part of being undetectable is IP address management. If you use a VPN, don't even bother trying to be undetected. VPNs are so slow you'd think it's illegal for their commercials to say they're fast. The answer is to build a national network where a node of bots is placed in a real physical location, and is programmed to get a clean IP address from the actual area it's in which prevents the server from knowing it's a bot. For example, if you're in Chicago and you route your data through a Miami IP, it'll be so consistently slow that the server will assume you're using a VPN or spoofing, but if those bots are actually in Miami, it gives the server nothing to detect as there is nothing to slow down the internet connection.
      Here's why JS/Python is too slow: I need these bots to do more than play videogames. I need them to factory reset themselves, connect themselves to the correct new IP address, receive commands, and use tesseract OCR to analyze the screen. As this system deals so much with networking, it made sense to design it with a local computer handling everything that needs handling. Nothing else could be faster, so for the sake of being more undetectable and the sake of saving time I need a local computer.
      As buying tens of thousands of androids is expensive enough, I decided controlling each node controller should be an Android phone - preferably the cheapest one possible since it'll really only be dealing with running a timer, executing android commands on the local networks, tesseract analyzation, and sending data back and forth between each node and my database caching server. This isn't something you need a strong computer for, but more bots demands more compute. I'd like to run 1 controller per 100 bots, but my original build is in Python which is way too slow even for running 10 devices. Rust is considered to be anywhere from 20-40 times faster depending on the task being measured, so Rust is perfect as it should comfortably get me over a hundred bots per controller.
      The reason I'm joining the Rust cult, though, isn't just due to speed. It has a dev experience that sounds incredible with the bug checking compiler, it runs on everything, and it has the versatility JS claims to have (node.js is absolute garbage for example - I only learned it because I was scared of learning another language, and that was a MISTAKE as Flask is stupid easy to get running and demands like 10% of the code).
      Hope that wasn't too boring.

  • @matthewpaquette
    @matthewpaquette 6 หลายเดือนก่อน +1

    Beautiful is an interesting word of choice

    • @codetothemoon
      @codetothemoon  6 หลายเดือนก่อน

      DUDE. Editor Matt! I used to watch Matti all the time, so I'm a huge fan of your work. As you can imagine I was very confused at first about how you came across this video, but I watched your "I quit video" video and things came into focus a bit :)
      How has your coding journey been so far? What are you interested in and what's been your go-to stack lately?

    • @matthewpaquette
      @matthewpaquette 6 หลายเดือนก่อน

      @@codetothemoon Hahaha no way! Hope my comment didn’t come across rude 😅 just being silly. Great tutorial.
      I got into media / creative automation systems for an agency. I was actually building a Tauri + svelte app for work and was doing som rust research today!

  • @edgeeffect
    @edgeeffect 2 ปีที่แล้ว +4

    Nice!
    System Rust, Backend Rust, Embedded Rust, Frontend Rust.... Just need JVM Rust now so we can do Android development too.
    I can't say I'm enamoured with Rust's syntax... way too many unintuitive symbols.... but we'll get used to that eventually.... I love the idea of one (typesafe) language for all application areas.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Yeah, I initially found the Rust syntax off-putting. But in retrospect I think it might have been more due to my internal biases from using other languages for so long. I remember thinking that all the #s and !s looked ugly, but I think I've gotten used to them now

  • @rathodsandeep32
    @rathodsandeep32 2 ปีที่แล้ว +1

    Thank you so much your instructions were so easy to follow !! This helper a lot ❤️

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Nice, glad you found it valuable Rathod!

  • @rzr1191
    @rzr1191 2 ปีที่แล้ว +15

    WebAssembly is not competing with JavaScript it's aiming to fill the gaps where JS falls short. For actual web UI it's actually counter-productive to use WASM - a better use-case is heavy computation like image processing which can be run async while JS runs your UI

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +4

      To your point - WASM currently doesn't make DOM manipulation any faster - but whether using it is counter-productive for a UI really depends on the use case. It also doesn't seem inconceivable that it will become more compelling for DOM manipulation when WASM matures a bit and it becomes faster. It's also very possible that will never happen - it'll be fun to see what happens in the next few years.

    • @manmanmanichfindekeinennam7613
      @manmanmanichfindekeinennam7613 2 ปีที่แล้ว

      @@codetothemoon The thing is, that Javascript is actually more than fast enough for UI development. And with typescript and a framework its easily possible to build big Webapps that serve millions of users aroumd the world.
      So yeah we just need to wait and see whats going to happen in the next few years.

    • @fergmorris3939
      @fergmorris3939 2 ปีที่แล้ว

      great, this was exactly what I was looking for!

    • @v0xl
      @v0xl 2 ปีที่แล้ว +1

      image processing can be done with web workers too but of course wasm is faster

  • @MorpheusMusics
    @MorpheusMusics 2 ปีที่แล้ว +21

    Seems like a step back compared to react. Though, I’m interested in seeing how this develops in the near future.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +2

      It's possible that you're right. It'll be interesting to see how the ecosystem develops as Yew and WebAssembly mature a bit.

    • @DanKaschel
      @DanKaschel 2 ปีที่แล้ว +13

      Bleeding edge is a step back from a fully mature ecosystem? Umm, yeah.

    • @samuelgunter
      @samuelgunter 2 ปีที่แล้ว +7

      how is this a step back? the rust code requires a bit more boilerplate, but that's worth it for the speed you can achieve

    • @d3j4v00
      @d3j4v00 2 ปีที่แล้ว

      React is slow and bloated tho

    • @NucEn
      @NucEn 2 ปีที่แล้ว +2

      @water although, if I understand correctly, it's slower only with DOM manipulations. If your app performance is bound by something else (e.g. Figma is not reliant on DOM manipulations, but still quite heavy on performance), wasm should be much faster in those cases.

  • @tetuaoro
    @tetuaoro 2 ปีที่แล้ว +1

    Wooowwwww 🤩 glad to be there rustian. Thanks for this video.

  • @lukaszkulak7920
    @lukaszkulak7920 2 ปีที่แล้ว +1

    Było się zakochać a nie strzelać do ludzi. Rzuciłeś to i dobrze. Radom się broni. Mówicie że to wasz były prezydent, ale to tak wszyscy mówią.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      I used Google translate to translate to English, but I'm still not sure I understand... This is what it gave me:
      "It was to fall in love, not to shoot people. You dumped it, and good. Radom is defending himself. You say it's your ex-president, but that's what everyone says."

  • @agoncecelia
    @agoncecelia 2 ปีที่แล้ว +4

    This is a very nice informative video! Thank you

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Thank you, it was really fun to make!

  • @dankennedyulor4108
    @dankennedyulor4108 ปีที่แล้ว +1

    Really enjoyed this. For those that might encouter some difficulties while using intellijIDEA, style.css file can be created from the 'RustFrontEnd folder' above '.idea folder'. Right-click ==> New ==> File ==> and name it 'style.css'
    For the bug from line 13-20, here is the correct one which worked for me
    let onclick = {
    let state = state.clone();
    Callback::from(move |_| {
    state.set(Model {
    value: state.value + 1
    })
    })
    };
    goodluck all.. Let's get rusty

  • @arturomedina2055
    @arturomedina2055 2 ปีที่แล้ว +3

    Can it be debugged on VS Code?

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Good question, I believe so but I haven't tried yet as I haven't created much more than small toy programs so far. Probably just a matter of getting the right extensions.

  • @gordonlawrenz7635
    @gordonlawrenz7635 2 ปีที่แล้ว +2

    What is the size of the final wasm bundle? I only tried wasm bindgen and those bundles were quite heavy.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Don't have the size of the one for this specific app on hand, but I just took a look at the one I'm currently working on (which is not much different) and it's 5.7MB. Yikes. Hopefully there's a solution for this at some point :(

  • @deaafrizal
    @deaafrizal 2 ปีที่แล้ว +1

    woaaaa, i need to try this one. it's look hard, but beautiful. 🤪

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Give it a shot and let us know how it goes!

  • @TheItamarp
    @TheItamarp 2 ปีที่แล้ว +3

    What really should have been explained is when you would want to use this. You could code this with Vanilla JS in like 4 lines of code (and be backwards compatible even as far as ie6) vs 30 lines in Rust (with less backwards compatibility), and I seriously doubt the performance in Rust is markedly better.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      I could have done a better job covering this! If creating this counter app was the ultimate goal, we'd never need anything other than JS. Think of it as a stepping stone to larger projects where using Rust actually would provide an advantage.

  • @abbasbvohra
    @abbasbvohra 8 หลายเดือนก่อน +1

    Thanks for this very useful video.

    • @codetothemoon
      @codetothemoon  8 หลายเดือนก่อน

      thanks for watching!

  • @skydivertyler
    @skydivertyler 2 ปีที่แล้ว +3

    For anyone coding along, there is a bug in the code shown in the video:
    At 5:06, he mentioned to not put a semicolon in this place, but there _should_ be both a closing parentheses, then a semicolon ");"
    (CTTM, if you're reading this, a pinned comment would be very helpful)
    Another issue I encountered: If you use "rand" (version 0.8.3) as a dependency in the Cargo.toml file, you'll get the compiler error "the wasm32-unknown-unknown target is not supported by default" (I wonder if "getrandom" version 0.2.7, which appears to be installed by Trunk, causes some conflict?)

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +2

      Thanks for pointing this out, I'll make a pinned comment per your suggestion!

    • @skydivertyler
      @skydivertyler 2 ปีที่แล้ว

      @@codetothemoon thanks!

  • @dazealex
    @dazealex ปีที่แล้ว +2

    Rust is cool. Maturity will come with time, but lots of neat things are being made every day. I'll stick to Go for now. But keeping Rust in mind, as it is super cool and challenges how you think about memory management.

  • @lardosian
    @lardosian 2 ปีที่แล้ว +2

    Must give this a try, mostly use React and Node myself, but I watched a video today where the guy claims learning Rust has made him a better programmer even if he were not to continue using it.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +2

      Yeah imo Rust is definitely worth learning and toying with even if you don't wind up using on a project (yet). Let us know how it goes!

    • @lardosian
      @lardosian 2 ปีที่แล้ว +1

      @@codetothemoon Thank you!

  • @paulsalele3844
    @paulsalele3844 2 ปีที่แล้ว +1

    Awesome, now I'm going to learn Rust and I'm a React Developer.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Nice! Doesn't hurt to give it a try!

  • @FugalBaboon
    @FugalBaboon 2 ปีที่แล้ว +1

    Would love to see more videos like this!

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Thanks, they are in the works!

  • @marianapretti19
    @marianapretti19 ปีที่แล้ว +1

    very good video, I was looking for it. 👍

    • @codetothemoon
      @codetothemoon  ปีที่แล้ว +1

      glad you got something out of it! one thing I'd point out that didn't exist at the time this video was made - the Leptos framework. I now have a vast preference for it over Yew, so I'd definitely check it out if you're building a Rust frontend these days. Most of the concepts in this video still apply there

  • @Xblow23
    @Xblow23 2 ปีที่แล้ว +4

    The code as provided in the video doesn't compile lol, I wonder if that left on purpose :P These are minor things though, so easy to figure out.
    Thanks a lot! Really cool!

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +4

      I apologize for this!!! I believe I made some corrections and then erroneously left those fixes out of the video. Sounds like you have it figured out already but you can find the completed code in my GitHub repo! github.com/Me163/youtube

    • @shadamethyst1258
      @shadamethyst1258 2 ปีที่แล้ว

      I only see a missing closing parenthesis for the Callback::from function, a missing mut on the state variable and a missing semicolon for onclick. These are all things that the compiler would guide you to fix

  • @danvilela
    @danvilela 2 ปีที่แล้ว +1

    Awesome video! Loved the way this looks like React. gonna try it sometime.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Thanks for watching, glad you liked it! I think it's worth a try, even if you don't wind up using it.

  • @LakanBanwa
    @LakanBanwa 2 ปีที่แล้ว +2

    Since you're really into rust, you might also be interested in the proposed replacement for electron, Tauri!

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      I've heard of Tauri but haven't been able to dive into it yet - I'll add it to the list, thanks!

  • @unheilbar
    @unheilbar 2 ปีที่แล้ว +2

    Is there websocket implementation for wasm in rust?

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      I haven't tried it, but there appears to be - check out the "websocket" Rust crate. Not sure if it can be used in a WASM context.

  • @henriquematias1986
    @henriquematias1986 2 ปีที่แล้ว +2

    what would be the advantage over using npm and javascript? i am not really convinced by rust frontend so far...

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Right now there are a few possible justifications - (1) Preference for Rust features that compile-to-JS languages don't have, (2) Expectation that Yew will become faster than JS frameworks when WASM matures a bit, or (3) Rust is used elsewhere in the project (either on the frontend or backend) and there is a desire for language homogeny across the entire stack. Ultimately it depends heavily on the team and use case.

    • @henriquematias1986
      @henriquematias1986 2 ปีที่แล้ว +1

      @@codetothemoon hard to justify writing rust on the frontend when most of the things like adding events to buttons can be done with a more elegant syntax using javascript. I can understand justification of Rust if you need performance algorithms, strongly typed code being compiled, etcs, but for small things like programming the UI it seems ( based on your tutorial ) to be a lot of extra work to make a hello world.
      If we get to something similar to next.js written in Rust i can start seeing it become close to a reality but now ( based solely on your tutorial ) it looks like a nice proof of concept.

  • @stevenhe3462
    @stevenhe3462 2 ปีที่แล้ว +1

    Yew're great!
    And CSS is really the headache part.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Haha thanks Steven! Yeah CSS gets a little crazy, I've heard TailwindCSS makes things a bit easier but I haven't tried it yet

  • @thangphan6047
    @thangphan6047 2 ปีที่แล้ว +1

    Thank you so much 😊

  • @saysthetedd
    @saysthetedd ปีที่แล้ว +1

    This reminds me of Elm. I like it… Maybe Rust is for me after all!

  • @fernandourrutiasalazar2875
    @fernandourrutiasalazar2875 ปีที่แล้ว +2

    merci beaucoup a toi :))

    • @codetothemoon
      @codetothemoon  ปีที่แล้ว +1

      de rien, merci d'avoir regardé !

  • @umarchy
    @umarchy 2 ปีที่แล้ว +1

    Loved the tutorial... Keep it up.

  • @andydataguy
    @andydataguy 2 ปีที่แล้ว +1

    Awesome video!! Love your channel

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Thanks Anand! Many more to come.

  • @sandhawke
    @sandhawke 2 ปีที่แล้ว +2

    "french braces"? In 40+ years of coding, I've never heard them called that. Wikipedia has 21 names for them, and that's not one of them.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Thank you for pointing this out! I had a bit of an existential crisis when my Google searches came up empty for "french braces"! I think I may have had a college professor that referred to them that way. Somewhat to my relief, the wikipedia page for "Bracket" references "French brackets" as slang for "Curly brackets". Still, it doesn't seem to be a common way to refer to them so I should probably transition to saying "Curly brackets" =X

  • @Mixesha001
    @Mixesha001 2 ปีที่แล้ว +7

    The tech is cool but when it’s about DOM manipulation i think JS will still be the king just because of the ecosystem. I know that the WASM devs are confident that WASM will be able to be at least fast as JS. I hope for more JS alternatives. Blazor from Microsoft seems to be disappointing in terms of performance. Looks very cool. Thanks for the video!

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +4

      Yeah Yew doesn't appear to provide a substantial performance advantage yet for DOM manipulations yet, though from the benchmarks I've seen it seems to be in the same ballpark as React. All performance tests outside of DOM manipulation seem to favor Rust/WASM over JS though.

    • @echoptic775
      @echoptic775 2 ปีที่แล้ว +1

      Wasm wasnt intended to replace js, but to work together with it. Who knows myb wasm will be a better alternative than js some day, but i doubt it with such a big js ecosystem

    • @digitalspecter
      @digitalspecter 2 ปีที่แล้ว

      @@echoptic775 It depends.. Rust has pretty big ecosystem as well, albeit with different focus (atm).. if more computation-heavy logic is moved to the front-end it'll come handy and wasm will be the way to deliver that performance. IF they do bridge that wasm-dom gap in a good way in further wasm -development.. it can disrupt the status quo.

    • @echoptic775
      @echoptic775 2 ปีที่แล้ว

      @@digitalspecter i honestly hope that happens, so many people hate working with js and nodejs, but in a lot of cases they are forced to. I also have high hopes for wasi, i think theres a lot of potential in it

  • @igorfv
    @igorfv 2 ปีที่แล้ว +2

    I'm curious about the bundle size and how it scales with the amount of code written. It wouldn't be worth to have a really fast app if it weights 20mb

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +2

      I'm curious as well, my understanding is that this is one of the current shortcomings of writing an entire frontend in Rust. Haven't built anything big enough to thoroughly kick the tires on this yet though.

  • @aqdasak
    @aqdasak 2 ปีที่แล้ว +2

    You explained very beautifully. I have a question. How can we pass arguments to onclick handler?

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Thank you! I *believe* you should be able to add parameters to the closure using the pipe operators immediately prior to the first french brace after "let onclick="

  • @mihaiprocopi5053
    @mihaiprocopi5053 ปีที่แล้ว +1

    5:22 why not to use return keyword and avoid any kind of stupid issues?

    • @codetothemoon
      @codetothemoon  ปีที่แล้ว

      yeah that's an option, I can definitely see some development teams having a lint rule that disallows returning values without the "return" keyword for this reason. It's so easy to accidentally add a semicolon unintentionally.

  • @maxterrain
    @maxterrain 9 หลายเดือนก่อน

    This proves that just because it can be done doesn't mean it should be done.

  • @gamer-gw9iy
    @gamer-gw9iy 2 ปีที่แล้ว +3

    Are there any disadvantages for using rust instead of some JS library? I read somewhere that wasm isn't fully developed yet -- Something about modifying the DOM being slow if I remember correctly -- But it looks like rust -> WASM will definitely be a big part of the web pretty soon if it can deliver the speed and (comparably to similar higher-level languages) tiny sizes rust programs have 😯

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +5

      Great question! I think one of the main disadvantages right now is the relatively small size (as compared to React) of the community around frontend Rust / Yew. From the benchmarks I've seen it looks like DOM manipulation performance is roughly on par with React at the moment, but the creator of Yew believes WASM will have a DOM manipulation performance edge once a few new WASM features are added. For most things outside of DOM manipulation, it's already reasonable to expect WASM to be faster.

    • @gamer-gw9iy
      @gamer-gw9iy 2 ปีที่แล้ว +2

      @@codetothemoon Does including yew in your code build the whole yew package into the WASM?

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      good question, to be completely honest I'm not sure. I need to read more about how libraries are linked.

    • @gamer-gw9iy
      @gamer-gw9iy 2 ปีที่แล้ว +1

      @@codetothemoon Apparently, "Yes and no. The entire yew crate is included by default. But the Rust compiler and wasm-opt does tree shaking that removes most unreachable code." -- It does optimize it where it can, I'm loving rust more and more here😂

  • @DavidAlsh
    @DavidAlsh 2 ปีที่แล้ว +1

    Looking forward to wasm being anywhere near complete so languages like Rust and frameworks like Yew can actually be practical

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Me too!

    • @DavidAlsh
      @DavidAlsh 2 ปีที่แล้ว

      @@codetothemoon I suspect interface types can't be far off now. I think that's the big one holding back DOM access in wasm modules
      Also thanks for this video, it's such a great tl;dr of Yew

  • @jcolindres001
    @jcolindres001 ปีที่แล้ว +1

    Hi Sir,
    As of today; which is the best rust front end framework or which would you recommend?
    Regards,
    JA

    • @codetothemoon
      @codetothemoon  ปีที่แล้ว +1

      I don't have a ton of experience with it yet, but I've had a great experience with Leptos so far. It takes a more "batteries included" approach than Yew, and if you're also building a backend to support your frontend, it should definitely be an option to consider. It eliminates a lot of the boilerplate logic you'd otherwise need to shuttle data between the frontend and the backend.

  • @thelenardjourney8525
    @thelenardjourney8525 2 ปีที่แล้ว +1

    Thanks so much man. Legend

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      you're very welcome, glad you found it valuable!

    • @thelenardjourney8525
      @thelenardjourney8525 2 ปีที่แล้ว +2

      @@codetothemoon i run a tech start up with a few others and as a long-term side project we're building a front-end rust framework that works similarly to svelte but in rust.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      @@thelenardjourney8525 oh nice, I'd be very interested in trying that out when it's ready!

    • @thelenardjourney8525
      @thelenardjourney8525 2 ปีที่แล้ว

      @@codetothemoon will be a little while but will let you know once it’s done for sure!

    • @thelenardjourney8525
      @thelenardjourney8525 2 ปีที่แล้ว +1

      @@codetothemoon our first version for our start up will be released in a few weeks. The entire backend and database we built in rust, whilst currently the frontend is built in svelte. Keep making your vids because they’re great. Only started learning rust about 4 months ago and I love it

  • @estuardohernandez4230
    @estuardohernandez4230 ปีที่แล้ว +1

    This video is gold. However, I would like to know, What documentation did you use to learn on this label Rust? Could you please share the books used to learn Rust?
    Regards,

    • @codetothemoon
      @codetothemoon  ปีที่แล้ว +1

      Thanks Estuardo! I mostly just used the official Rust book, and watched quite a few "Let's Get Rusty" videos.

  • @joemac84
    @joemac84 2 ปีที่แล้ว +1

    Looks great for a simple example but when we start looking at state management for a large scale application how does it hold up?

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      great question - I haven't personally built a large app with Yew, but my guess it would be very similar to doing so with React. Also like React, there seem to exist libraries for helping manage state akin to Redux. I haven't tried it but there is one called Yewdux

  • @Cryptopunkstar
    @Cryptopunkstar 2 ปีที่แล้ว +1

    Amazing fast product :) and safe !

  • @riccardoesclapon549
    @riccardoesclapon549 ปีที่แล้ว +1

    I'm sorry but no github repo? I followed the entire tutorial and wrote every line of code, but I'm getting an error on trunk serve. At 5:03 you explain not having a semicolon, but isn't there a parenthesis missing there? I'm just getting started with Rust and I have no clue what I'm doing wrong, I checked all the code and looks identical. If only there was a repo 🤦‍♂

    • @riccardoesclapon549
      @riccardoesclapon549 ปีที่แล้ว +1

      after driving myself crazy a bunch, turns out that parenthesis was indeed missing (which I'm like 99.9% sure wasn't in the video's code) and I got the app working. PLEASE add a github repo for reference.

    • @codetothemoon
      @codetothemoon  ปีที่แล้ว

      sorry about the confusion Riccardo! There is indeed a mistake in the video. The github repo is here github.com/Me163/youtube/tree/main/RustFrontEnd. I'll add it to an "Errata" pinned comment

  • @yassinesafraoui
    @yassinesafraoui ปีที่แล้ว

    Don't forget to increase the zoom level when recording, the screen looks crazy unreadable on a phone screen

  • @mr.soumikdas
    @mr.soumikdas 10 หลายเดือนก่อน

    But, what's the point of all this if at the end it's still slower then the moder js alternatives like solid/svelte ? .......although i really love the idea of wasm and like rust on a language construction level, i would still stick to js for FE and Go for BE

  • @andrewchen1744
    @andrewchen1744 2 ปีที่แล้ว +1

    You deserve more subscribers!

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Thank you! I really enjoy creating these videos, it makes me happy to see others finding value in them.

  • @gvcallen
    @gvcallen ปีที่แล้ว

    Have you had a look at Dioxus? Would love to see an example and initial thoughts, as well as how it compares to Yew. My initial impressions of Dioxus, with the rsx! syntax, is that it is definitely easier to use

  • @007sya
    @007sya 2 ปีที่แล้ว +2

    Great Video! But what are the pros of doing any application in Rust is this going to be much faster? I mean React with typescript is very very fast

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +2

      Thanks! To your point, TS/React is probably sufficiently performant for most webapps. But there are performance critical use cases that can benefit significantly from Rust/WASM, see this testimony the Prime Video team: www.amazon.science/blog/how-prime-video-updates-its-app-for-more-than-8-000-device-types
      Some might also argue that Rust is preferable irrespective of any performance gain - ie just for the language itself.

  • @raffimolero64
    @raffimolero64 2 ปีที่แล้ว +1

    very cool video, gets you started with the basics
    also the missing close paren on line 20 was mildly off putting

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      glad you enjoyed it! yeah, i botched that. Find the full working code at my GitHub repo (link in the description)!

  • @yanfoo
    @yanfoo 4 หลายเดือนก่อน

    "error: could not compile `yew` (lib) due to 1 previous error" because of "error[E0277]: the trait bound `implicit_clone::unsync::IMap: From` is not satisfied"
    Ooops.

  • @stumblinzz
    @stumblinzz 2 ปีที่แล้ว +1

    Thanks!

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Wow thank you so much AH, this is much appreciated!!!! 🔥

  • @Shaunmcdonogh-shaunsurfing
    @Shaunmcdonogh-shaunsurfing 2 ปีที่แล้ว +1

    Awesome! Is there a “Next JS” equivalent for Yew?

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Thanks for watching!
      I haven't tried it, but maybe check out Percy which support SSR - github.com/chinedufn/percy

  • @RobertoGPuentesDiaz
    @RobertoGPuentesDiaz 2 ปีที่แล้ว +1

    Is there way to ser work Rust and React together?
    How can Rust help to React? Do you can imagine some context?

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      I haven't done it, but yes I believe you can incorporate WASM into any JavaScript based app by building JavaScript bindings for your WASM code.

  • @sohn7767
    @sohn7767 2 ปีที่แล้ว +3

    This is great

  • @drunkgerman
    @drunkgerman 2 ปีที่แล้ว +1

    Awesome tutorial! I was wondering how the onclick variable is working, even one semicolon is missing on line 20.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +2

      I corrected some mistakes but neglected to put those corrections in the final edit. The final version of the code can be found in my github repo, Me163/youtube. In the future I'm going to either show the mistake corrections or redo the entire recording.

  • @Direkin
    @Direkin ปีที่แล้ว +1

    Svelte to the left of me, React to the right. Here I am stuck in the middle with Yew.
    ...I'll get me coat.

  • @mahdi_c200
    @mahdi_c200 2 ปีที่แล้ว +1

    thank you

  • @heitormbonfim
    @heitormbonfim 2 ปีที่แล้ว +1

    That's beautiful

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Thanks! Nothing more satisfying than a button with a counter.... ;)

  • @NeotenicApe
    @NeotenicApe 2 ปีที่แล้ว +1

    Really good tutorial. Would love to see you make something more complex.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Thanks, glad you liked it! Currently working on more complex projects, stay tuned for those videos!

  • @gjermundification
    @gjermundification 9 หลายเดือนก่อน

    Does yew have passportJS like something? I would like to have a login screen using SSO; such as keycloak.

  • @johnwilliams7999
    @johnwilliams7999 2 ปีที่แล้ว +2

    I’m guessing no hot reloading

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      actually trunk serve does support hot reloading! Such a time saver!

  • @Deniil2000
    @Deniil2000 2 ปีที่แล้ว +3

    6:24 CSS moment, you can see pain and confusion in his eyes

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Correct! You might say CSS is not my.... style.....

  • @ramseybeing
    @ramseybeing ปีที่แล้ว

    would be good to know perhaps the version of rustc and nightly, because im getting a lot of errors. also you have an unclosed delimiter of Callback of the move function i believe.

  • @CYXXYC
    @CYXXYC ปีที่แล้ว

    idk if this was the case when the video was uploaded, but if you use a closure/fn as a prop (ie somewhere in html! tags) it automatically gets wrapped in a Callback, as per Advanced Topics/Struct Components/Callbacks Yew documentation

    • @CYXXYC
      @CYXXYC ปีที่แล้ว

      this allows:
      let onclick = {
      let...
      move || ...
      }
      html! { ... { onclick } ... }
      or even
      html! { ... onclick={ move || ... } ... }

  • @christianmartinez2179
    @christianmartinez2179 2 ปีที่แล้ว +2

    One thing I hate about rust is their take on returns as "no semicolon means implicit return" and most rust devs do that which makes the code harder to read because unless you're paying attention to every line end you might not notice there is a return and the fact that rust is so verbose and syntactically overwhelming at times makes it worse, reading an implicit return naturally with all that noise just doesn't come naturally to me.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      I agree! I actually spent quite awhile trying to figure out why my code didn't work - it actually turned out to be because the last line of a closure had a semicolon, causing the closure to return nothing! Rust is an incredible leap forward in terms of achieving memory safety with no garbage collector, but it seems to leave out a lot of the syntactic goodness that some other modern languages have.

  • @jbrown-acuity
    @jbrown-acuity 2 ปีที่แล้ว +1

    Incredible!

  • @Truformable
    @Truformable 2 ปีที่แล้ว +1

    you have blazingly fast internet and everything is just works magicly good if follow that hello world path without any turns...

  • @alexzander__6334
    @alexzander__6334 2 ปีที่แล้ว +1

    how do you build this thing for production ? make a video.

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Great question, I plan to make a video addressing this sometime in the coming weeks!

  • @RedStone576
    @RedStone576 2 ปีที่แล้ว +1

    awesome!

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว

      Thank you and thanks for watching!

  • @darcy6698
    @darcy6698 2 ปีที่แล้ว +1

    please tell me how you got syntax highlighting for the inline html in the `html!` macro !! please....

    • @codetothemoon
      @codetothemoon  2 ปีที่แล้ว +1

      Actually I don't think I did anything special to get this, it seems like VSCode just knew it was html somehow!

    • @darcy6698
      @darcy6698 2 ปีที่แล้ว

      @@codetothemoon ah nice . i had to install a brand new extension to do it , but the rust code inside html! then does not highlight