Great to see someone go beyond the click counting example 🙂
@HagbardCelineOnRust2 жыл бұрын
you deliver this quality content so fast, i can not even watch it. ty. and iam so lf to 2023, my rust year. superb work
@avinashthakur802 жыл бұрын
Thanks for such an informative video. It was clean & without any distraction, just on point.
@casecamel67192 жыл бұрын
it would be super useful to make tutorial on little more complicated examples like, passing around data through components, pages, writing rest apis and receiving and sendting to other servers.
@thedevnoteyt2 жыл бұрын
Very informative video Chris. Please bring more videos on Yew, if possible 🙏
@hythamsoliman2 жыл бұрын
+1
Жыл бұрын
Thank you, I'm glad to know that someone else had the same problem with the json fetch at the end.
@rexma73942 жыл бұрын
I would love to see a Leptos tutorial. I think it's inspired by SolidJS and most of the issues you had with Yew (defining a component name for example) don't look like so bad in Leptos
@chrisbiscardi2 жыл бұрын
I've put it on my list to look into
@AreQ2122 жыл бұрын
Regarding 14:23, just think about an Option as a single element List, then it makes more sense. Same as Tree in which all nodes have only one child is a List.
@chrisbiscardi2 жыл бұрын
It turns out there's a clippy lint for preventing this approach in other contexts, so especially interesting it was chosen here -- rust-lang.github.io/rust-clippy/v0.0.212/#for_loop_over_option
@jl4zz2 жыл бұрын
Great stuff Chris. Thoughts on ergonomics vs Dioxus, Sycamore, or Leptos? Found simple things like nested lists get really ugly, really quickly in these Rust front ends.
@chrisbiscardi2 жыл бұрын
I think Rust frontend in general is a pretty hard sell. Some tools like Sycamore advertise as "anti-JS" which is a really tough position to be in with a large community-sized lift to rebuild an ecosystem on top of. Dioxus is really early in it's lifecycle and if you have any JavaScript skills at all I'd recommend going full Tauri over Dioxus' piecemealing of Tauri's crates. I haven't worked with Leptos at all. The popular state of the art in frontend JS is heavily influenced by VC funding though, so the ergonomics of Rust on the frontend has to compete with companies who are well funded and trying to onboard you quickly and lock you in. This often results in fast onboarding but high-maintenance applications over time. So I could see Rust building an ecosystem that isn't driven by the same factors that could be very productive. It'll take a lot of work from a bunch of people though.
@redcrafterlppa3032 жыл бұрын
9:00 I didn't know you could destructure in the function arguments. I will definitely use this here and there
@j-wenning2 жыл бұрын
That fetch/unwrap chain is pretty 1:1 with a JS fetch promise chain. Fetching can fail, and deserializing a response can fail. JS has the benefit of being able to catch *any* error with a try/catch or chained .catch. the same code in js: const data = await fetch('/tutorial/data.json') .then(data => data.json()) .catch((err) => handleErr(err)); OR try { const res = await fetch('/tutorial/data.json'); const data = await res.json(); } catch (err) { handleErr(err); } handleErr would then have to handle both request error types, and deserialization error types. So it's just as much (if not more) boilerplate to write something that actually handles both error types cleanly.
@Sethbeastalan8 ай бұрын
That's a really good point. I wonder if that can be handled smoothly with some macros.
@aimpizza6823 Жыл бұрын
Has anyone figured out the proxy problem? I independently followed the yew tutorial and am stuck with the same behaviour EDIT: Digging through the Yew Discord I found that if you cleared the cache (or visit in an incognito window as I did) it works as expected. I have no clue why or how to prepare for such an issue but that's at least a temporary fix
@intendednull2 жыл бұрын
Awesome video! Would be interested to see your thoughts on Yewdux. It doesn't try to be Redux 1:1, but should be relatively easy to pickup for people familiar with flux-like libs.
@chrisbiscardi2 жыл бұрын
Video today took a look at yewdux. It was very easy to pick up and follow the todomvc, etc examples
@dario.lencina2 жыл бұрын
Awesome video Chris!! I am adding it to my Rust Frontend Playlist!!
@Codeaholic12 жыл бұрын
I think it would be interesting to see a bigger React tutorial implemented in Yew.
@chrisbiscardi2 жыл бұрын
yeah I agree. I'm planning on doing some more Rust UI explorations across a couple of tools. Is there a specific React app that you'd like to see?
@Codeaholic12 жыл бұрын
@@chrisbiscardi I only know enough react to be dangerous. But something interfacing with a database, accepting and storing data and then mixing in push based real-time events would be awesome.
@corear2 жыл бұрын
Great name... will *never* be confused with Vue...
@DBZM1k32 жыл бұрын
Yew better enjoy the Vue from over there.
@michaelsegel8758Ай бұрын
Nice Demo / Turorial. One small nit... the video doesn't match the tutorial doc and this could cause some confusion. Current tutorial version is 0.21 ...
@temoncher2 жыл бұрын
It is cool to see more wasm presence on the web, but this syntax, boilerplate and clones everywhere.. It looks very much like rust and react are just not meant to be used together like that
@workflowinmind2 жыл бұрын
I saw Yew mentioned many times, but never really understood the need, after this video I can safely say that in it's current form I don't have any application for it at work. Performance wise, could you potentially draw more/faster in WASM?
@chrisbiscardi2 жыл бұрын
wasm doesn't have access to the dom, so you're not going to get faster dom updates afaik. It can be useful for performance if you're doing a lot of calculation, which is why I think some of the primary usage of wasm right now is with wgpu -> canvas interactions or other computationally heavy use cases.
@MonLes-xt7gc Жыл бұрын
How do you split the screens perfectly
@johnt1342 Жыл бұрын
Ugh, hot reload isn't working? Nothing updates when I save my rust code.
@chrisbiscardi Жыл бұрын
You should file an issue with the project then. I was using hot-reload yesterday with the new release and it was working for me.
@NotBrisk2 жыл бұрын
What program are you using to have your windows work like that? And with the rainbow background?
@chrisbiscardi2 жыл бұрын
I use yabai on macos, and the rainbow background is my own gradient desktop image from photoshop. I go over it here: kzbin.info/www/bejne/l6GoiaCAhZqrrtk
@LucasOe Жыл бұрын
What ls tool are you using?
@chrisbiscardi Жыл бұрын
Nushell
@larrymarso44922 жыл бұрын
Thoughts v sycamore? I've had positive though limited experience with sycamore -- but it looks better than this! However interoperability with Javascript libraries seems a no-go. A Yew tutorial including such would be illuminating.
@chrisbiscardi2 жыл бұрын
I'll do some videos on sycamore too. I'm pretty skeptical of anything that advertises as "anti-javascript" in general and sycamore's homepage saying "Had enough of JavaScript? So have we." as a main selling point is meh IMO. Giving up the very fast moving JavaScript ecosystem's libraries means you have to rebuild everything against a moving target so would require a very large community-sized lift for that to pan out, or a specific use case.
@larrymarso44922 жыл бұрын
@@chrisbiscardi thank you so much for your reply. Is Sycamore anti JavaScript from a programmatic standpoint, or simply philosophically. In other words, does it stand in the way of JavaScript library compatibility for the intrepid? I don't know how much Yew bends over backward to support JavaScript library compatibility -- which I thought was an issue with wasm-bindgen in general? (Library, not calling individual commands intentionally exported). Again, appreciate the response.
@chrisbiscardi2 жыл бұрын
@@larrymarso4492 seems philosophical since it's on their homepage. They do have a documentation page on interop: sycamore-rs.netlify.app/docs/advanced/js_interop but they're still pre first release afaik (suggested installation method is the git repo) so not all docs are filled out and we'll see how it evolves
@noblenetdk Жыл бұрын
To use this video: learn react...?
@simdimdim2 жыл бұрын
for details, lets watch next video :D
@NotBrisk2 жыл бұрын
Chris very great video yet again!
@displayname7t42 жыл бұрын
Thank you for this tutorial !
@quantumquantified2 жыл бұрын
nice video chris
@workflowinmind2 жыл бұрын
Fast watcher!!
@navneeetraj2 жыл бұрын
Flashhhh!!!
@gumispro2 жыл бұрын
U BEST!!!
@jonathanlevi2458 Жыл бұрын
You don't have to use curly brackets for text. Only if you want to use a Rust string literal...for some reason. `Hello World` also works.