The Truth about Rust/WebAssembly Performance

Поділитися
Вставка
  • Опубліковано 13 січ 2025

КОМЕНТАРІ • 298

  • @gbjxc
    @gbjxc  Рік тому +204

    Sorry for the super small text! I forgot to bump it up in the terminal, but it's not a coding-focused video so hopefully it doesn't ruin it for you!

    • @gbjxc
      @gbjxc  Рік тому +24

      @@DavidChoiProgrammer Somebody buy me a time machine and I'll make as many videos as you want :-D

    • @sck3570
      @sck3570 Рік тому +4

      @@gbjxc hopefully Elon will build one for us using Rust

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

      @@gbjxc on my way 😂🌌

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

      Hey Greg, excellent video and awesome to see how good wasm already is. I would love a video on what would need to happen to make wasm faster than JS. Like go wild with what could happen, e.g wasm can manipulate dom, css, wasm spliting, ect. Intuitively, in my mind Rust should be able faster than JS as Rust is faster than JS, is there a flaw in this reasoning?

    • @user-zq8bt6hv9k
      @user-zq8bt6hv9k Рік тому

      How fat a wasm library is? Last time I checked, a wasm hello world example was megabytes fat

  • @chrisbiscardi
    @chrisbiscardi Рік тому +362

    I appreciated the way you talked about the entire ecosystem in a positive and uplifting or factual way here

    • @gbjxc
      @gbjxc  Рік тому +87

      Thanks! I think we’re all trying actively to avoid framework wars etc. For example, Dioxus team just made a couple PRs to Leptos to make server functions framework agnostic, etc. It’s all just Rust, in the end…

    • @__jan
      @__jan Рік тому +15

      @@gbjxc Rust community is good at this kind of collaboration, because people have a strong desire to break out common components into their own crates that consolidate the ecosystem by allowing interoperation between different crates in the same category, examples include mint, winit, etc.

    • @maxmustermann-hx3fx
      @maxmustermann-hx3fx Рік тому

      @@gbjxc That is so wholesome convinced me to now learn Rust before my Systems Programming course starts next semester. Then I can use Rust instead of C or C++.

  • @forivall
    @forivall Рік тому +114

    The creator of solidjs was a former co-worker of mine, and the framework we used at that company was god awfully slow, so it's pretty cool that he's created such a fast framework!

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

      in interviews and such he always seems like a cool guy, what's he like to work with?

    • @forivall
      @forivall Рік тому +22

      @@oxey_ this was in 2014, so it was a while ago, but yeah, pretty cool; I can remember that he was passionate about solving problems. Although my experience with that job was overshadowed by our abusive boss, though I don't need to get into that.

    • @MadsterV
      @MadsterV Рік тому +18

      working with awful code has been one of the main drivers for writing reusable solutions for me

  • @oxey_
    @oxey_ Рік тому +63

    honestly besides the WASM vs vanillajs differences there's a LOT of information in this video, about how virtual DOM works, about various framework internals, there's the string encoding part and all your videos are like this, these really feel like a behind the scenes type video which is really cool

  • @elina6969
    @elina6969 Рік тому +502

    Maintainer of Yew here, this video was very helpful and informative. I want to clarify for any readers that the latest version had a performance regression which is fixed in git repo but it being a community maintained project, none of the maintainers have had the time to release it.
    I would like to have a chat about web assembly performance and improving Yew's performance, if you, Greg, or anyone else, is down for that

    • @gbjxc
      @gbjxc  Рік тому +114

      This is awesome to hear! I’ve done a couple small experiments with using wasm_bindgen string interning with Yew and found it dropped results in this benchmark down to the 1.48 range, which is great. I’ll open an issue to discuss when I have a little time.

    • @gbjxc
      @gbjxc  Рік тому +86

      (Just posted some stuff in the Yew discord assuming you're hamza1311 in there)

    • @fadichamieh
      @fadichamieh Рік тому +56

      great to see this collaborative spirit guys...

  • @ceriusgeek2749
    @ceriusgeek2749 Рік тому +55

    Maybe it was unintentional but, I learned so much from this presentation that you earned yourself a subscriber.

  • @ahmadaccino
    @ahmadaccino Рік тому +33

    Really well formulated video. As a react dev interested in moving to wasm, this was a perfect intro into the space

  • @aniketfuryrocks
    @aniketfuryrocks Рік тому +14

    As the creator of GxiRs-gxi, I am thrilled to witness developers carrying forward the idea that I had envisioned for wasm front-end frameworks. Due to time constraints, I haven't been able to devote much attention to the project myself. Nevertheless, I want to express my utmost support and enthusiasm for the ongoing progress. Kudos to all involved in the project!

  • @social.elenakrittik
    @social.elenakrittik 10 місяців тому +1

    Thank you SO much man for how you've done the introduction! I wish more people did this "gist-of-the-video" type of intros, it saves so much time!

  • @tommycard4569
    @tommycard4569 Рік тому +3

    Continuing to enjoy the organization, clarity, and focus your videos. Keep up the great work!

  • @romanstingler435
    @romanstingler435 Рік тому +27

    Greg, I highly appreciate your content. I already compared the table back in the days but I love your thoughts and opinions.

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

      Thanks, that's really kind!

  • @hoodwinkedDaDon
    @hoodwinkedDaDon 8 днів тому

    You're a great presenter, i could watch your talks all day. fantastic content

  • @rtsa4633
    @rtsa4633 6 місяців тому

    Such an informative video man. I really enjoyed the behind the scenes explanations from an expert like yourself :)

  • @seannewell397
    @seannewell397 Рік тому +20

    Perf is one thing, the DX, the platform, and the options are another. Edge rendering, hybrid apps, RSC, sharing ts types... So much has gone into the JS ecosystem that my hesitation has been "what _else_ will I be giving up?" or "what does a full stack rust platform/stack look like?"
    FWIW i think lamba/edge starts for rust + using wasm in the browser could be spectacular. Like give 2-5x runway on free tiers perhaps if based on compute time!
    But dev productivity is an interesting angle, higher startup, lower maintenance?

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

      After messing with Yew for a while, I came to the conclusion that a Rust WASM project will make sense if:
      1. You just love Rust.
      2. You do need that faster startup times (especially on the free tier thing).
      3. You need predictable performance in certain scenarios.
      4. You have a much more defined code structure and will not be changing.
      It's as you've said.
      JS has had so much around its ecosystem that makes it easy to prototype and overcome some of its shortcomings.

  • @DMSBrian24
    @DMSBrian24 Рік тому +72

    The "hope" of WASM replacing HTML+CSS+JS altogether isn't really from the performance standpoint, it's from development standpoint. Being able to develop everything in eg. Rust, skipping all the current kinks of JS, overall reducing the overhead as well as workload, the entry barrier, pretty much everything about it would be awesome and I'd pick this any day over a traditional front end stack even if it was a bit slower initially.

    • @DMSBrian24
      @DMSBrian24 Рік тому +8

      And yeah, I know doing this is not the original/current "point" of WASM, but hey, one can only hope...

    • @d.sherman8563
      @d.sherman8563 Рік тому +10

      Id say that’s the main reason people don’t use rust for fe actually. Far less mature and smaller ecosystem, high barrier to entry (new low level language to learn with a huge amount of things there aren’t libraries for and you’ll have to write yourself) all for a very marginal performance gain.

    • @lukaspotthast2142
      @lukaspotthast2142 Рік тому +18

      @D. Sherman It is not about performance gains. It’s about leveraging the knowledge you gained by writing your backend in Rust. It’s about the language Rust being miles ahead of the clusterfuck that JavaScript actually is (and TypeScript, who’s type system has so many Problems of its own..). It’s about not needing the whole JS ecosystem and just using all the libraries you are already familiar with (serde, tracing, …). It’s about having the same „if it compiles, it works“ experience when developing your frontend.

    • @lukaspotthast2142
      @lukaspotthast2142 Рік тому +12

      To the ecosystem. Rust was already mature enough 1 or 2 years ago. Libraries like Axum (backend) and Leptos (frontend) can be used in production without needing to write any additional libraries.
      To the learning curve: I would MUCH rather learn and master one single langue I love to use, instead of constantly dealing with different languages that all feel lacking in some aspects.

    • @DMSBrian24
      @DMSBrian24 Рік тому +4

      @@d.sherman8563 That's always gonna be the case with new languages, especially complex ones like Rust. Still, enough people are clearly on board because of all the advantages it offers. A couple years back I hadn't even heard of the language, I got into it because of the FOSS community and nowadays I see local job postings from both startups as well as established companies looking for Rust devs - I'd say this rate of adoption is relatively fast, even if you compare it with early developments of eg. Python, which only really exploded in popularity in the last 10 years or so (it's easy to forget it's much older than javascript). I agree that Rust is complex and tough to learn (so is C, Cpp, Java and many others if you want to write good code in them), but I'd say it's already mature enough for production and rising adoption in the industry proves it. And since a lot of people already write desktop apps in it and it's actually quite amazing for creating GUI's (largely thanks to the macros), being able to essentially make webapps on the fly with WASM wouldn't just be convenient, it would be a game changer for the whole industry.

  • @l3p3
    @l3p3 Рік тому +3

    There should be a conference of all lead devs of the frameworks of this benchmark. I am in!

  • @desuburinga
    @desuburinga Рік тому +11

    Thanks for shedding light on some of the misconceptions about Rust and WASM! It is really cool to see there's actually not that much of a difference between vanillaJS and other Rust frameworks! What an exciting time we live in!

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

    Ok, after days of searching and fiddling around, this video answered all of my questions. You sir, are a godsend. Was so confused with different frameworks and opinions. Thanks again!

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

    Man! You are cool bro! Take it to the benchmarks! Nailed the interpretation of the results. Showing immense knowledge of frontend frameworks! Wow! Keep it up!

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

    This was incredibly helpful to understand the differences between these frameworks. Thank you

  • @allesarfint
    @allesarfint Рік тому +10

    The part that I'm interested the most about rust FE frameworks is the server-side speed, you can generate pages orders of magnitude faster with rust compared to nodejs, with the bonus of everything being written in the same language, so no dealing with js for client-side. But the amount of code to transfer and the memory usage is what turns me away from using a WASM framework the same way I don't want to touch React with a stick, and that's because of mobile. Most people daily drive slow devices with unreliable mobile internet connections, which is a problem when the page they try to use takes ages to load, doesn't download properly, or just straight up crashes the browser because of high memory usage, something more common than one would expect.
    I really hope WASM improves and resolves the issues holding it back, so we can finally get to use another real language in webdev, besides HTML.

    • @JuliaOrtiz-ti6ku
      @JuliaOrtiz-ti6ku Рік тому

      If you’re facing those kind of issues with any JS library even in fairly complex applications it’s most likely an implementation problem. Most popular frameworks are heavily optimized for bundling and load speed. Besides, not using js to generate pages in the server is how the web has been from the beginning, using js for that is a fairly recent thing so I think you’re going in circles here.

    • @phoenix-tt
      @phoenix-tt Рік тому

      @@JuliaOrtiz-ti6ku The idea is that now you can do JS for both client and server side code. And since JS is not at all ergonomic, Rust tries to replace it. It's very easy to do SSR, but for client-side code Rust Wasm is not mature enough to compete with JavaScript.

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

      so true on the wasm part for mobile. On facebook instant, the goal is to get very fast load times for games. Well, with wasm from Unity its not even possible to reach 2s load times even with an empty project (for low end mobile devices).

  • @verified_tinker1818
    @verified_tinker1818 Рік тому +10

    This was illuminating. Thanks, Greg!
    I think the biggest drawback of WASM for front-end apps is iteration time. Changes you make in your code can take a bit to compile and show on the screen (and you’ll lose whatever state the app was in), whereas JS reflects them immediately. This is less important if most of your changes are to the logic and not the visuals, but otherwise, it can be a pain.
    Speaking of, would it be possible to somehow separate the logic from the visuals? To detect if the changes necessitate recompiling? Maybe the dev environment could have a watcher/build script that morphs the DOM instead, like Phoenix seems to?

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

      In JS the Vite do a fantastic job!

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

      The js frameworks basically wrap each of your components in a hot reload component that stores the props and listens for hot reload signals from the bundler system, which is tracking what modules change on the dev server then sending what changed down a websocket.
      The way they currently do components Rust hot reload would need some deeper hooks into the build than I believe they currently have the ability to add, not just to detect what changed but probably also to split out the user code from the framework code (at the moment you can only really have one wasm file with one memory space) - but there's definitely ways to get around this, for example separate, non Rust, components that the dev server can treat differently but a "real" build can inline (and optimize) - it's just a lot of complex work that can't reuse much.

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

      That's exactly what Dioxus does! If you make an update only to the "component template" (the code in the rsx macro) - then Dioxus will dynamically update the DOM tree, without recompiling the whole app.
      Albeit it's not ideal - if you change something on the rust side in macro (like code in event handler), it will still trigger the whole app rebuild, as you need to recompile rust.

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

    Great video, very informative and you have a great character and spirit!

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

    great vid! loved the passionate narrating, half an hour worth spent :p

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

    Really interesting comparison. Thanks!

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

    Very informative. Thank you for your work on this video.

  • @steve-adams
    @steve-adams Рік тому +1

    At 10:50 -ish you mention 20 characters of UTF-16 being 20kb. Would it not be 40-80 (2b to 4b encoding) bytes?
    Awesome video and explanation. This is the first video of yours that I've seen and I subscribed immediately.

  • @yukas1ngas
    @yukas1ngas Рік тому +9

    It's very possible that WASM will be more popular in serverside than in browser.
    WASM-containers are really interesting

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

      IMHO WebAssembly carries the potential to break all system / hardware specific limitations and should allow true reusable code for so many use cases!

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

      @@fadichamieh The most important is absence of pointer arithmetic in principle.
      You don't need to check something that not exists.
      And there are a lot of task where security prevails over performance

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

    Great video! Just found your channel. Looks awesome 🙌🏾

  • @stephenbrown-bourne465
    @stephenbrown-bourne465 Рік тому

    Really insightful video. Definitely going to consider wasm for my next project now

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

    Awesome overview, thanks for the video😁

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

    Wee need this. Keep up the good work 👍

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

    Love your presentation!

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

    The man! Glad to find you.

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

    that was actually pretty interesting indeed ! thanks

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

    18:40 - Surely yew could do this too? Or is there a technical reason why these performance improvements couldn't be added to yew?

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

    This is great content, learnt a lot from this!

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

    Super interesting video, very informative. Thanks!

  • @andreialdea6072
    @andreialdea6072 Рік тому +7

    Greg, the leptos man, you're doing good work here, full of coconut oil

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

    Like the content, would appreciate if you could consider linking resources (in this case: I stopped the video and manually went to the js framework benchmark page) in the description?

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

    Such a great and informative video!

  • @derschutz4737
    @derschutz4737 Рік тому +4

    My thing is it felt like the memory part was just glossed over, thats a huuuge part of the performance I care about. You mentioned it could've been a leak, but this is supposed to be a basic benchmark so what are the chances all WASM frameworks are leaking in a basic program. If I am building a big app, I really do not want to be 3x the memory footprint of svelte/solid. Is there anyway WASM will be as memory efficient? I am not just talking about the startup metric, I mean overall. Are there scenarios where GC spikes will effect JS framworks but not WASM?

    • @gbjxc
      @gbjxc  Рік тому +4

      Yeah let me clarify: my point here is that the way memory is being measured in the benchmark doesn’t capture the actual memory usage. I’m not sure why it changed but if you look back at older benchmarks that were taken on OSX you see the memory usage is much more comparable krausest.github.io/js-framework-benchmark/2022/table_chrome_103.0.5060.53_osx.html I don’t know why the measurement is different on later Chrome versions and/or on Windows.

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

      There' 2 different memory models being used -- with the rust/wasm examples, it's not that more memory is being used, just that more memory is being set aside to be used. Think of two different beach parties: one where the kids go wild, soda cups get left on the ground, and you send in the garbage person the next day to tidy up; and another where there's a defined area allocated for waste disposal. It might look like a lot of space is set aside for waste in the second case, but in reality it's a lot easier to manage such a party that way than just letting everyone throw their drinks cans on the floor.

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

      @@thirdvect0r My thing is, if my app is setting aside memory that isn't actually being used. That is still memory being taken up by my app, what I don't want is that the memory set aside is scaled alongside the actual memory being used, if its a fixed offset or just a buffer that eventually gets filled up when memory usage passes a certain point, then that's fine. So by memory usage all I am saying is that I don't want my rust app to have less memory available for other processes compared to a solid/svelte one. It doesn't really matter to me if technically speaking the rust one is actually a buffer and not the totality of actual used memory.

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

      @@gbjxc I'm just defining memory usage as, the delta between the total memory that are available for other processes to use before/after the app is loaded. Is it measuring that? And part of that includes some allocated memory not actually being used yet? For me, even if that 's not technically being used, if other processes can't use it then it counts as memory being used. Or is the memory usage just totally off and completely unrelated to real world memory metrics? I am curious why the windows results are so different than the OSX ones though.

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

      In my eyes memory usage is way more important of a factor than speed

  • @brynyard
    @brynyard Рік тому +7

    Web isn't used for it's performance. The reason web and performance is mentioned in the same sentence is because we need to find ways to mitigate all the performance challenges web has. Working on a large scale 3D multiplatform renderer the discussion about "fast" JS frameworks is quite silly. In our comparisons it's just a matter of "not that much slower" (ie: at least we're not counting orders of magnitude), "dead slow" (orders of magnitude) and "won't even run" (usually because of lack of/bad memory/resource management).

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

      Your writing makes no sense. Nobody argued: let's go web, because it's so fast. Point is, if you want to collaborate in real time (if it is work, or gaming, or whatever) over distance, you need something like the web. And than performance matters, even 10th of seconds. You don't think so? Try to enjoy a movie with delayed sound.

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

      @@frankszander2761 Uhm, you say that nobody says this, and then in the next sentence _you_ say it! Or what do you interpret as "The Web"?!
      I happen to write a collaborative app framework, and yes, over a distance, and NO, web is NOT something I need, because I don't need more problems. In the performance world I live in, fractions of milliseconds matter (that is fractions of 1/1000's of a second), and having to live in a VM with random stalls and no guarantees about timing is not ideal if you expect do do anything realtime.

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

      @@brynyard Well, the clip is about WebAssembly and FWs to build Webpages. And no. I said people use the web because that is the common (and for some the only) way to collaborate over a distance and not because of the performance.

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

    Thanks for this type of content!

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

    Dude! Great breakdown

  • @BeffJezos69
    @BeffJezos69 Рік тому +3

    That whole point about compile time verification of component diffing absolutely blew my mind. But it makes perfect sense. Holy heck that’s cool

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

    Great overview, and I really like the deep dive into why the differences seen are there, as well as the context of what it all means.
    As a developer who primarily works in back-end or automation, I'm unfamiliar with the constraints of front-end work. Is it possible to get sub-second interactive page loads, or are we doomed to the 1.8s interactivity floor you showed in the chart? I know 1.8s is still "fast" by most standards, as the teams I help are often pushing 5-10 seconds before interactive, but the dream of a desktop-equivalent experience is that everything feels real-time without delay.

  • @ktappdev
    @ktappdev Місяць тому

    Solidjs mentioned! lets go!

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

    Hey Greg, Loved the video , Just one quick question, I am lactose intolerant can I use Leptos?

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

    Great video, thanks!

  • @talananiyiyaya8912
    @talananiyiyaya8912 Рік тому +6

    In before Primeagen steals this content to fill time during his stream.

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

    This channel is incredible! Really enjoy your delivery style, and love the content with nuanced perspectives that aren’t black and white.

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

    that looks like a good choice for something that has to do a lot of state changes purely on the client side without any server interaction. will be interesting to see what will happen once DOM modification directly from WASM is possible. i'm not too sure though how this would work out for low-frequency state updates with a roundtrip to the server ... might well be that minimal js and server-side rendering (e.g. actix-web + sailfish + htmx) would outperform here. for sure for the loading performance, but maybe also for rendering. browsers are extremely fast on html processing. obviously, your changed DOM causes html processing in the browser as well, but i talk about processing/diffing larger chunks as it would happen if the whole table got replaced by a server roundtrip.

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

    Glad to see SolidJS as representative of the JS frameworks.

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

    Great video

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

    this is great. at this point my priorities revolve around developer experience

  • @BosonCollider
    @BosonCollider Рік тому +9

    Imho, the real tradeoff at this point is Rust vs Typescript frontend ecosystem.
    Overall I am really interested in Dioxus' rendering approach, since I also think it also works better for native backends where the cost of repainting rectangles isn't hidden away behind the DOM abstraction, and there is a lot of potential to optimize the rendering backends there. But of course at the same time the state management part of the react model is quite clunky, and signals or something similar is a great way to separate the rendering tree from the state tree. Imho, meshing Dioxus' approach with Vue's state management model is very promising.
    With that said, imho I would really have loved to see how logic programming languages would do for GUIs, and wasm is a promising platform to host other scripting languages than JS (speed is no longer the goal here). The main reason is that logic programming languages is probably the single best way to make two-way data binding work.

  • @xuedi
    @xuedi Рік тому +4

    Optimizing web apps in the 0.% to save milli seconds ... then Marketing comes in and adds 4MB of tracking and other stuff that blots the apps performance 1000x ^_^

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

    Great video thanks bro

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

    Thank you for a great overview, that was very informative and useful for us, "traditional" JS devs :D

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

    I think currently the dev experience of Rust in the frontend compared with frameworks like Svelte or Vue, is very bad. And that's pretty important too: Run time vs Code time. I think in the near future we'll see devs migrating to WASM but there is still a lot of work to do to compare JS experience with Rust in the frontend. Thanks for this helpful information!

    • @eyz-4
      @eyz-4 Рік тому

      development experience is subjective. from a maturity standpoint it's not there. as far as writing code, i personally find it to have better dx. it's easier to start a project with js but gets harder as it grows. rust is the exact opposite where it's harder to start a project but gets easier as it grows. there are trade offs to both so it depends on the app you are intending to build.

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

      @@eyz-4I think is not subjective when you can write less boilerplate and code in general so write a very simple component. Do you think a framework like Svelte or Vue scale worse than another Rust web framework? No way...

    • @eyz-4
      @eyz-4 Рік тому

      @@SilvestreVivo there's less boilerplate/code in leptos than react or vue. svelte has the least but svelte is it's own language which makes that possible. leptos is just a clone of solid js/solidstart in rust. the leptos server api is also much simpler to implement than kit, nuxt, and next.

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

      @@eyz-4This confirms me that Svelte is sill easier that any web framework in Rust. That was my point. Maybe in the near feature will be different but not currently.

    • @eyz-4
      @eyz-4 Рік тому

      @@SilvestreVivo yes but svelte is not javascript. it's a completely different language that has it's own compiler. it has such great dx because it's not javascript. solid has comparable dx to svelte and rust has better dx than js. even then svelte is not a completely sure thing for every project. the server api as i said is very confusing compared to the leptos server api. you don't get the type safety and other features that the rust language offers. on top of that leptos is faster on the client and server by a significant margin so you get performance advantages. there are trade offs to both so it comes down to the project and what you're intending to do.

  • @kylestubblefield3404
    @kylestubblefield3404 Рік тому +5

    I saw nvim and harpoon!

  • @JG-nm9zk
    @JG-nm9zk Рік тому +31

    well you see the problem here is you are using a browser.

    • @tuanva6484
      @tuanva6484 6 місяців тому

      He is such a idiot when compared ssr and csr 😂😂😂😂

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

    I wouldn't pick rust over javascript for effeciency. I don't think we need better performance on the web today, but more statical typing and robustness, while keeping the access to web development pretty easy. The goal to me is to find a way so that with very little knowledge we can't mess up code and create invisible bugs, incoherent dependencies, while at the same time it shouldn't be very hard to develop a good web application. Rust looks a like a very good language for that, thank you guys for the frameworks you're developping!

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

    Is there a list where we can see the websites using these Rust UI frameworks?

  • @CuriousSpy
    @CuriousSpy Рік тому +3

    The perfomance of wasm wasn't an issue for me as a frontend developer. It's the ecosystem behind framework. Frontend is not just interactivity (do smth on btn click). What about css support inside thoseframeworks? It's a big pain to even setup windi/tailwindcss properly. I have to use vite to bundle all my app (i know about rust alternatives they just very raw). What about animation capabilities? All those stuff matter and it's really sad to see that most of these frameworks are focused only on rendering perfomance. Yeah it's good. What's next?

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

      Forgot to say thank you for video. Very helpful and interesting

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

    Great video!

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

    How did you set your text editor line numbering (in vim I assume)? That way of showing the line you are on and then the relative distance from that line is a brilliant move that I never thought of until this moment.

    • @gbjxc
      @gbjxc  Рік тому +4

      I’m a total nvim newb and copied my whole config from ThePrimeagen pretty much :-) the term here is “relative line numbers” I think. Super great for your j and k navigations

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

      @@gbjxc Be careful with nvim, I just spent my entire day configuring it :P.

    • @charetjc
      @charetjc Рік тому +5

      `:set rnu` to turn on, `:set nornu` to turn off relative line numbers

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

    you are a great teacher man

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

    There is no need to "access the DOM directly" for WASM, because it's not what it was created for. But I still don't understand why to move HTML code into Rust if it doesn't make any performance difference - for an experiment? For fun? Or for something else?

    • @gbjxc
      @gbjxc  Рік тому +4

      Simple: 1) It’s a language I’d much rather be writing than JavaScript, in which I can express myself better and create fewer bugs 2) It performs much better on the server than JS, and writing single-language apps on the whole stack is great.

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

      I bet there will be a performance difference once you do more complex things besides editing the DOM.

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

      @@gbjxc You could have said from the beginning that you don't like JS and you just want to write in another language 🤣
      Create less bugs? How about to use typescript instead?

    • @julians.2597
      @julians.2597 Рік тому +2

      @@f1amesoff because the safety improvement from JS to TS is similar to the improvement from TS to Rust

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

    29:00 why wouldn't you use Leptos for an e-commerce? Stability? Or an e-commerce would need the best performance all-around, hence something like SolidJS would be better? Or for other reasons?
    BTW your content is great, thank you!

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

    Very insightful, thanks for sharing. Now I wonder how I can apply this to webgl performance 🤔

  • @florianbopp187
    @florianbopp187 Рік тому +3

    Super interesting! As a frontend dev mostly working with vue, it’s so weird to me that it’s always dismissed so easily especially with it’s insane performance even though it is using v-Dom and it’s great community and easy to use api. Once vue 3 has vapor mode it should be on par with solid performance wise.

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

      I think some people are simply jaded. It's like with Java, modern Java is amazing, but people remember the Java 1.5 days where doing just about anything sucked and younger developers haven't tried Java and just listen to the jaded seniors.
      Vue is probably in a similar situation.

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

      @toast Why is it a nightmare? You've got SFCs, typescript, ... What are the issues causing the nightmare?

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

      @toast I am working on a large project with vue and can’t complain. Vue 3 is awesome and has super easy to use APIs, the script setup syntax is basically identical to how svelte handles JS, vue 3 was completely written in typescript so that is also covered and the composition API and the ability to outsource logic into dedicated, statefull, TS modules is an amazing feature. I haven’t really worked with svelte a lot so I can’t compare the two fairly, but I can say that DX in vue 3 is first class!

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

    *Notice's Primeagen's harpoon vim plug*
    _"Ah, I see you're a man of culture as well"_

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

    What I don't get is why all of the performance metrics seem to be around accessing the dom instead of just equivalent graphical effects entirely in wasm, have I just entirely misunderstood wasm itself?

  • @СлаваВолошин-ы3с

    Absence of separation info smaller bundles and lazy loading can be a problem for bigger rust front end apps.

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

    is there a benchmark using a large, real life like project - say twitter like - that compares the load time and bundle sizes for leptos and javascript libraries? how does it "really" compare?

    • @matress-4-2323
      @matress-4-2323 6 місяців тому

      i know that airbus uses dioxus on their commercial planes. a lot of it is dependent on the specific project. twitter could be feasible, but it wouldn't make as much sense. wasm suffers the most with creation and i imagine twitter would have more than normal creation costs. apps like facebook, instagram, gmail, slack, etc, would make much more sense. the bundle might be larger with wasm, but it's also streamed into the browser which offsets some of that. time to interactive isn't an issue regardless just because of progressive enhancement. the main benefit of full stack wasm frameworks is server side performance.

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

    4:41 HA! There is my framework lui finally mentioned, at least in the form of text. xD

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

    I'd like to see DX improvements for rust wasm ecosystem and rust in general.

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

    That's really interesting about the cost of strings. Could you guys use utf-16 strings in the rust implementations?

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

      It’s a good question - That may be a possible micro-optimization, but the issue is that the Rust String type is defined as UTF-8 so you either lose the *whole* ecosystem for working with strings in Rust, or pay the (relatively small?) performance cost. Certainly framework architecture ends up swamping the string cost, because Leptos/Dioxus are faster than Svelte/Vue/Preact etc simply because of our architectural choices.

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

      @@gbjxc ​ Wow, I was not expecting a direct response from the creator a leptos-rs himself 😂. Primeagen is always hyping up what a cool tool this is. It probably would be more trouble than it was wroth, but I didn't know if you could use utf-16 strings for a subset of operations like accessing dom nodes as you mentioned earlier, and only perform the conversion when you needed the full power of the rust ecosystem.

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

    Greg, thank you

  • @technologyondemand4538
    @technologyondemand4538 Рік тому +5

    I'm using Dioxus at the moment :p

    • @gbjxc
      @gbjxc  Рік тому +5

      We love Dioxus! (I mean, we love Leptos more but you know, we're all on the same team :-) )

  • @Jonas-Seiler
    @Jonas-Seiler Рік тому +1

    I don’t why there is even this much of a discussion about performance, to me it was clear from the beginning, if react is fast enough, and its more than fast enough really, then pretty much everything else will also be fast enough. The speed of ui rendering is almost never a bottleneck on user experience anyways.

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

      probably the only thing is 3d engines, they don't access to DOM but use many cpu resources in calculations, but i don't think wasm can help with gpu calculations performance.

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

    Very Great content

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

    Amazing content.

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

    What a charismatic talker!

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

    These tests are based on DOM manipulation. As far as I know, WASM reaches out to JS to perform all the DOM manipulations.
    So there will in fact be a bottleneck right there.
    However, using heavy computational non-DOM functionality in WASM will be lightning speed faster than JS. ;)
    So this test actually only shows how fast is DOM being manipulated. Not how fast Wasm is. WASM is not meant for DOM manipulations.

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

    Is V8 able to auto-vectorize JavaScript code? If it isn't, applications could benefit from manual SIMD implementations in WASM

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

    I like the video, I might try some WASM on my portfolio. I agree that bigger applications might require a little more thought, the part that scares me the most is the size of the bundle, i hope WASM gets a code splitting feature, if they do, then its done. Greg I'd love to know why rust based frameworks were taking memory on startup even though they might not use it? Is it something rust related? I'm new to rust, I'm still reading the book and doing the rustlings course.

    • @mwcz5190
      @mwcz5190 Рік тому +3

      One silver lining of wasm's generally-larger bundle size, is that wasm parsing can be streamed, so by the time the file is done downloading, it's pretty much already parsed and ready to execute. Contrariwise, JS files can't be parsed until they're fully downloaded (AIUI), and that parsing cost is larger for JS due to complex text syntax's disadvantages vs wasm's compact binary format.
      But still, I agree that code splitting should be made a lot easier. Right now, you have to create multiple wasm by hand and they can only communicate through JS. I don't know of any alternative to that at the moment.

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

      Whoops, I hadn't watched the whole video yet and Greg covered everything I just said. 😅

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

      @@mwcz5190 can WASM code run before everything is parsed?

    • @Andrew-jh2bn
      @Andrew-jh2bn Рік тому

      ​@@climatechangedoesntbargain9140 I believe the answer to that is no, everything has to be downloaded before it's ready to run.
      The browser can parse as the file is downloading, however, so it should be ready to go almost immediately after the last byte is received.
      I think JavaScript has to download the file completely before it can even begin parsing.
      The difference here comes from the fact that wasm is a binary format much closer to machine code, requiring the browser to do a lot less translating.

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

      @@Andrew-jh2bn yeah, but you can load JS incrementally, so it can run before everything is loaded, even though the inidivudal files have to be completely loaded before parsing.

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

    can we have hybrid model like micro frontends.. so that on a large team some can focus on high performant wasm based framework on some critical viewsand other in react/vue..

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

    How many more lines does it add compared to the equivalent javascript?
    Like how much tinier is the delivered website?
    And how much more convoluted will the implementation be?

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

    Do you have goals to make ur full stack framework compatible with multiple devices.

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

    New to rust, but why not use UTF16 in WASM to match JS?

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

    Using the link in the description I cannot see Sledghammer in the benchmarks. I also can't find it in the git repository. Is there a fork that includes the rust frameworks?

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

    Just a silly question. You said - "The main constraint is not actually the ability to call DOM apis from WA but the cost of copying strings from WA to JS". But then you at 10:00 say that - "creation ....where you have to generate a whole bunch of strings and ship them in to the DOM". So the constraints is actually accessing the DOM or transferring those strings from rust -> WA-> JS -> DOM. So if WA is able to access the DOM directly, wouldn't it be faster?

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

      Good question. Here’s a rephrase: What’s expensive is not the action of calling a DOM method from WASM via JS, it’s the cost of copying and reencoding a string argument. Direct DOM access or the WASM stringref proposal should remove the need to copy which would be great. I suspect reencoding to UTF-16 would still be necessary but I’m far from an expert. So yeah it should be a win but maybe not 100% of the difference!

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

      Yep.The web browser,JS engines etc today are so complex, that it's really difficult to say what will happen.

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

    I think the thing about UTF-16 is about Asia - iirc CJK, and probably other Asian languages, fit most of their codepoints into a single UTF-16 symbol. UTF-8 is actually very West-centric.

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

      It's probably the only thing JavaScript and Java have in common. Java's default string representation is also UTF 16. So it could have been taken over from Java or have been some Java inter-operability thing.

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

      @@joachimfrank4134 Back when the decision was made the common wisdom was that "UTF-16 would be the future". That was back when "Unicode" was synonymous with the now defunct UCS-2. This turned out to be wrong. But hindsight is 20/20.

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

    this video made me realize how litte this all matters. all those meausrements are so close to each other percentage wise that there is really no difference between most of them.

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

    Thank you for creating wonderful library, now I can unlearn Javascript.

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

    I'm new to programming and I've been enjoying tutorial hell before I invest time into writing code. I was wondering if wasm can replace json?

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

    As someone happily running a 2011 CPU with the RAM maxed out to 32GiB for everything except web apps (I have a separate gaming rig I'm quite happy with... it's a hand-me-down of similar age with 8GiB of RAM and a Radeon HD 5870 from 2009), I'd say that WEB APPS IN GENERAL aren't ready for prime time, regardless of what they're written in.
    When normal "a few open tabs and a UA-cam video at 480p" web browsing doesn't reliably maintain better P99 janklessness than games like Superliminal or A Hat In Time, something's wrong.