Це відео не доступне.
Перепрошуємо.

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

Поділитися
Вставка
  • Опубліковано 18 сер 2024
  • How to build a simple web app frontend using 100% Rust - no JavaScript. WebAssembly opens the door for frontend developers to use languages that don't necessarily compile to JavaScript, including Rust.
    00:00 Introduction
    00:40 What We'll Build
    00:59 Environment/Project Setup
    01:44 Cargo.toml
    01:59 main.rs
    06:22 Styles
    06:29 index.html
    06:59 Build & Test
    07:16 Conclusion

КОМЕНТАРІ • 453

  • @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

  • @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

  • @dr-maybe
    @dr-maybe 2 роки тому +357

    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 роки тому +91

      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...???

  • @Hobbitstomper
    @Hobbitstomper 2 роки тому +63

    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

  • @santiagop.a1432
    @santiagop.a1432 2 роки тому +11

    This caught my attention immediately as I scrolled down my UA-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.

  • @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!

  • @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 UA-cam platform!

  • @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 11 місяців тому +1

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

    • @schmoris
      @schmoris 10 місяців тому

      Macromedia ColdFusion did quite a good job tho.

    • @nahiyanalamgir7056
      @nahiyanalamgir7056 10 місяців тому

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

  • @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!

  • @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.

  • @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.

  • @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?

  • @MunshiWahid
    @MunshiWahid 2 роки тому +4

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

  • @yt-sh
    @yt-sh 2 роки тому +1

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

  • @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!

  • @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 Рік тому +1

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

  • @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...

  • @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...

  • @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

  • @tetuaoro
    @tetuaoro 2 роки тому +1

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

  • @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.

  • @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!

  • @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!

  • @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

  • @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 😲

  • @greglocker2124
    @greglocker2124 Рік тому +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. Рік тому +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  Рік тому

      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 Рік тому

      @@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.

  • @rathodsandeep32
    @rathodsandeep32 Рік тому +1

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

  • @TozzaYT
    @TozzaYT Рік тому +1

    these sound effects are insane 🔥

    • @codetothemoon
      @codetothemoon  Рік тому

      Thanks, some might say I went overboard :)

  • @matthewpaquette
    @matthewpaquette 5 місяців тому +1

    Beautiful is an interesting word of choice

    • @codetothemoon
      @codetothemoon  5 місяців тому

      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 5 місяців тому

      @@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!

  • @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.

  • @abbasbvohra
    @abbasbvohra 6 місяців тому +1

    Thanks for this very useful video.

  • @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

  • @edgeeffect
    @edgeeffect Рік тому +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  Рік тому

      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

  • @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

  • @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 :(

  • @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!

  • @FugalBaboon
    @FugalBaboon 2 роки тому +1

    Would love to see more videos like this!

  • @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!

  • @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.

  • @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.

  • @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!

  • @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.

  • @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."

  • @andydataguy
    @andydataguy 2 роки тому +1

    Awesome video!! Love your channel

  • @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!

  • @umarchy
    @umarchy 2 роки тому +1

    Loved the tutorial... Keep it up.

  • @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!

  • @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.

  • @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

  • @Cryptopunkstar
    @Cryptopunkstar 2 роки тому +1

    Amazing fast product :) and safe !

  • @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

  • @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.

  • @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.

  • @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😂

  • @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="

  • @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.

  • @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

  • @saysthetedd
    @saysthetedd Рік тому +1

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

  • @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.

  • @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

  • @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

  • @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

  • @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

  • @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

  • @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.

  • @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.

  • @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.

  • @gjermundification
    @gjermundification 7 місяців тому

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

  • @yassinesafraoui
    @yassinesafraoui Рік тому

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

  • @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 || ... } ... }

  • @gillall4828
    @gillall4828 2 роки тому +1

    Great video!

  • @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!

  • @thangphan6047
    @thangphan6047 2 роки тому +1

    Thank you so much 😊

  • @Cm0nd00d
    @Cm0nd00d 2 роки тому +1

    great job on the video. can you compare performance to a react app?

    • @codetothemoon
      @codetothemoon  2 роки тому +1

      thanks! For benchmarks check out this krausest.github.io/js-framework-benchmark/2020/table_chrome_87.0.4280.66.html despite being called "Results for js web frameworks benchmark", it includes Yew as well

  • @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.

  • @nickjunes
    @nickjunes 5 місяців тому

    If it compiles to web assembly how is the debugging experience?

  • @johndavid3114
    @johndavid3114 Рік тому +1

    How big is the compiled wasm? Bigger or smaller than stuff like react's js?

    • @codetothemoon
      @codetothemoon  Рік тому

      I forgot the exact size, but it was much bigger than I would have liked - I believe it was in the megabytes (!). I think that is one of the biggest issues the developers of Rust frontend frameworks face today.

    • @anakenralf01
      @anakenralf01 Рік тому

      smt around 300kb

  • @mr.soumikdas
    @mr.soumikdas 8 місяців тому

    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

  • @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.

  • @haliszekeriyaozkok4851
    @haliszekeriyaozkok4851 Рік тому +1

    is that compiling in server side or client side?

    • @codetothemoon
      @codetothemoon  Рік тому +1

      compiles to WASM on the build machine, WASM gets delivered to the client browser, page gets rendered on the client side

  • @darcy6698
    @darcy6698 Рік тому +1

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

    • @codetothemoon
      @codetothemoon  Рік тому +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 Рік тому

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

  • @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)!

  • @michaelshort2388
    @michaelshort2388 Рік тому

    can Rust create apps with routing that doesn't require server requests to load pages, like react/angular etc do?

  • @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

  • @1879heikkisorsa
    @1879heikkisorsa 2 роки тому +1

    Nice videos, keep it up!

    • @codetothemoon
      @codetothemoon  2 роки тому

      Glad you enjoyed it, will do!!

    • @1879heikkisorsa
      @1879heikkisorsa 2 роки тому +1

      @@codetothemoon what are your next topics you wanna cover?

    • @codetothemoon
      @codetothemoon  2 роки тому +1

      I'm thinking the next one is probably going to be about setting up the infrastructure (CDK, Repos, CI/CD, etc) for a full stack Rust app on AWS - ie where both the frontend and backend are written in Rust. Would you be interested in that?

    • @1879heikkisorsa
      @1879heikkisorsa 2 роки тому

      @@codetothemoon In general yes, but it would be nice to not only focus on AWS! So I would prefer vendor agnostic solutions since we can't always choose the cloud provider for our projects.

  • @fernandourrutiasalazar2875
    @fernandourrutiasalazar2875 Рік тому +2

    merci beaucoup a toi :))

  • @maxterrain
    @maxterrain 8 місяців тому

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

  • @Muaahaa
    @Muaahaa 2 роки тому +2

    Hmm, cloning the entire state on an event doesn't seem great for an application that is or may become large. I wonder if this pattern popularized by redux is actually suitable with Rust's approach to memory management?

    • @codetothemoon
      @codetothemoon  2 роки тому

      I grappled with this as well - we can't take ownership because state is used in the component markup, and we can't borrow a reference because we call the set function. Would love to find a better way!

    • @vikumwijekoon3166
      @vikumwijekoon3166 2 роки тому

      Cloning the entire state seems wasteful. Utilizing a functional programming type would be a better idea to store the state

    • @vinjo360
      @vinjo360 2 роки тому +1

      That pattern is widely used in the elm architecture witch was a direct inspiration for this crate

    • @manmanmanichfindekeinennam7613
      @manmanmanichfindekeinennam7613 2 роки тому

      @@codetothemoon I think the need of having to use state methods could actually be wrong already. Rust already compiles to assembly, so why not bring reactivity directly into the language? Chaning a variable that is used in html markup should be enough for rust to update the UI..

  • @Apoorvpandey
    @Apoorvpandey 2 роки тому +1

    How to do styling and animations stuff

    • @codetothemoon
      @codetothemoon  2 роки тому

      CSS (and CSS based animations) work the same way they do in most other web frameworks! If you have a specific example of something you'd like to accomplish, I might be able to point you in the right direction.

  • @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.....

  • @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!

  • @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!

  • @EricRogstad
    @EricRogstad 2 роки тому +1

    At 4:24, missing a closing right paren on line 20?

    • @codetothemoon
      @codetothemoon  2 роки тому +1

      Thanks Eric, I think you are correct! I must have added it later and not included that in the video. I'll make a blurb about this in the video description!

  • @marcmarugan3565
    @marcmarugan3565 Рік тому

    Hi! Maybe it's a bit late to ask this, but I ran the exact same code as you, had some trouble with trunk serve as I had to install some other packages on my linux, but it finally doesnt show an error. However, after running trunk serve, I get the same messages as you in 7:05, but it stops at success. doesnt show me the last 2 messages and at my localhost:8080 I just get a "page cannot be reached" error. Any idea what I might be missing?