tRPC: Smart and Easy APIs

  Рет қаралды 121,859

Jack Herrington

Jack Herrington

Күн бұрын

Пікірлер: 190
@HussainFazaal
@HussainFazaal 2 жыл бұрын
This guy makes complex stuff so simple. What a great skill to have!
@billynitrus
@billynitrus 2 жыл бұрын
He’s got a great voice, could go into voice acting if he gets tired of software
@LuckiestManAlive
@LuckiestManAlive 2 жыл бұрын
11:05 - Out of the entire tutorial, as useful as it is... This is what I value the most. Being able to share the excitement of getting something to work when I barely know anything about it. Don't ever lose this energy Jack!
@angelxv01
@angelxv01 2 жыл бұрын
I really like how you teach different technologies and how excited you are to teach them. That’s really helping people getting involved! Keep up
@ogreeni
@ogreeni 2 жыл бұрын
I wanted to get started with tRPC, and the first thing I did was check if you’ve made a video about it.
@theyreMineralsMarie
@theyreMineralsMarie 2 жыл бұрын
I love seeing that tRPC uses React Query. It deserves to be the standard for all React http requests.
@jedliu8671
@jedliu8671 2 жыл бұрын
Share the same opinion!
@pieter-venter
@pieter-venter 2 жыл бұрын
I agree! We been using trpc for over a year now with Prisma and next and we're hiring. Hit me up on Twitter if you keen to join
@DanKaschel
@DanKaschel 2 жыл бұрын
I watched half a dozen videos today on this topic and this is the first one where I understood how to use it and where its trade-offs are. Great tutorial.
@DavidWoodMusic
@DavidWoodMusic 2 жыл бұрын
A few weeks ago I said you had a knack for dropping videos on exactly what I'm looking for. And you've done it again!
@chengxiaoxia8046
@chengxiaoxia8046 2 жыл бұрын
Thanks Jack. You saved me so much time by demystify the whole process, from setting up the development environment to wrapping up the project. Clean and effective code.
@aaronmotacek9343
@aaronmotacek9343 2 жыл бұрын
Ok a lot of awesome stuff, great examples, excited to discover you and subscribe, etc., but... that transition at 21:26! Had to back it up and rewatch that a couple times! Haha nice work
@b1n1yam
@b1n1yam 2 жыл бұрын
One of the best decisions I've made is subscribing to this channel. This guy is awesome!
@griffith488
@griffith488 2 жыл бұрын
Another fantastic video on new technology. Perhaps in pros/cons, on backend side trpc is only nodejs unlike REST, GraphQL, gRPC supported in most programming languages. Apologies if I missed that in the video. Really keen to try it out 🙂
@devwax
@devwax 2 жыл бұрын
Wow... how have I not heard of this channel until now? This is great. Thanks!
@optimus_gpt
@optimus_gpt 2 жыл бұрын
Great love it! Reminds me a bit of my WCF adventures back in the days where I could just import a wsdl file (versioned) on the client and I had the models and type safety setup within a breeze. ❤️ This comes really close. 👍🏻
@DanKaschel
@DanKaschel 2 жыл бұрын
I do not have fond memories of wsdl. In general, a workflow that requires a bunch of code generation eventually runs into synchronization issues unless there's a lot of discipline (or it's just a single developer). Not saying it doesn't have its place (in C# I'm find of linq2db with T4 templating), but I think sharing types between client and server without code generation is better than wsdl. ...Well, after accounting for everything you lose by not being in a strongly typed environment.
@optimus_gpt
@optimus_gpt 2 жыл бұрын
@@DanKaschel yes exactly it is nice when there are not a lot of devs involved. It works nicely in rapid development cases.
@sreekar_s
@sreekar_s 2 жыл бұрын
0:39 slick transition
@reemnourali4005
@reemnourali4005 2 жыл бұрын
Cool stuff! Please keep making videos like these. Ps: The video quality is getting sooo much better these days.
@RedCrafter07
@RedCrafter07 2 жыл бұрын
I didn't know anything about tRPC and this video explained it so well. Also, it wasn't boring at all. Thanks for the video!
@Ollinho12
@Ollinho12 2 жыл бұрын
Awesome stuff - been waiting for a good tPRC tutorial as I've seen a few devs use it
@simonflk
@simonflk 2 жыл бұрын
Great video, nice and clear thanks ❤ I feel like you undersold the benefits of that e2e typesafety a bit 1 other downside to tRPC compared to REST/GraphQL/gRPC that you didn't mention is that unlike those others tRPC is only useful if both your FE & BE are TypeScript. Technically it probably also works with a JS frontend, but you'd lose the main benefit I'm really glad I stumbled on your channel, lots of great content I can share with team mates
@jherr
@jherr 2 жыл бұрын
I would say that tRPC is no worse than REST in that situation. gRPC is kind of a different story altogether because protos define everything and you can't get around the protos. GQL is different again in that there is runtime introspection, which neither REST nor tRPC (or gRPC) have. Anyway, I think tRPC is a no downsides upgrade on REST, but tRPC vs GQL or tRPC vs gRPC is a different story.
@codewithguillaume
@codewithguillaume 2 жыл бұрын
Thanks very interesting ! Really thinking about how it could compete with GQL ❤️
@armaandhanji7151
@armaandhanji7151 2 жыл бұрын
Hope you can make a video that shows a production example of using rabbitmq or queues in the wild with a react app. Thanks for the awesome content!
@michaelfaith
@michaelfaith 2 жыл бұрын
Such a great walkthrough. Thank you!
@user-tz6nn8iw9m
@user-tz6nn8iw9m 2 жыл бұрын
love your vscode theme and font
@breytex
@breytex 2 жыл бұрын
Thanks for the vid, @jack. You are my fav. channel for getting react ecosystem news :D When you make a video about it, its about time to put it on the radar.
@fev4
@fev4 2 жыл бұрын
OOOKAY! Those transitions are cool
@petarkolev6928
@petarkolev6928 2 жыл бұрын
Wow! Amazing video, Jack! Thank you so much ❤
@eaglebirdiepar
@eaglebirdiepar 2 жыл бұрын
These new transitions are 🔥
@FacterNerz
@FacterNerz 2 жыл бұрын
What a cozy house I love that forest view
@tejasnikam3287
@tejasnikam3287 2 жыл бұрын
Thanks jack !!! All your efforts are priceless ❤️
@alastairtheduke
@alastairtheduke 2 жыл бұрын
Excellent and clearly explained. Trpc's advantage seems to be in its simplicity and speed in terms of design. As long as you're in a monorepo and are using typescript, I think it's a great option.
@dota2content755
@dota2content755 Жыл бұрын
One of the best ways to build apis wow can't imagine takes all the work using traditional rest APIS
@MishinMachine
@MishinMachine 2 жыл бұрын
Awesome and clear! Please make a tutorial of how to implement tRPC with nextjs 13 app directly
@wendanny6732
@wendanny6732 Жыл бұрын
Really awesome explanation
@NateGUMBC20
@NateGUMBC20 Жыл бұрын
great tutorial. thank you!
@mohammadmahdifarnia5358
@mohammadmahdifarnia5358 2 жыл бұрын
Thanks for monorepo. I didn’t know how to link those without npm link command
@wagnermoreira786
@wagnermoreira786 2 жыл бұрын
A-mazing content! I'm trying out the T3 stack and your video is incredibly helpful to understand trpc! question, shouldn't the onAdd query be auto invalidated because it suffered a mutation? I feel like forcing invalidation in the onSuccess callback shouldn't be necessary
@shubhamlatiyan7972
@shubhamlatiyan7972 2 жыл бұрын
Thanks, Jack for the always awesome video. Can we get a video on utilizing the workers in browser to at the best extent possible to get performance.
@jherr
@jherr 2 жыл бұрын
Definitely thinking about that one.
@AlexandrosFotiadis
@AlexandrosFotiadis 2 жыл бұрын
I personally use apollo client with graphql, I have the same features but trpc is also really interesting.
@canghaocai4574
@canghaocai4574 2 жыл бұрын
Thanks, Jack
@chris3079
@chris3079 2 жыл бұрын
I love you give the github repo. There is alot to like about the trpc, fresh, deno stack. So moving my stuff over. Keep running into small issues, like do i need a mono for trpc etc. Love more on this stack together. Also what scales better gql or trcp for request etc? Or should i just go server api. We always talk about developer happiness. But i want whats best for my consumer.
@jherr
@jherr 2 жыл бұрын
What scales best... Depends on what scales means to you. In terms of load I think tRPC scales better because the per-transaction costs aren't as high. IMHO, if you are offering API as as service, then go with GraphQL, if you are building both the server and the client, use tRPC.
@zomakaja
@zomakaja 2 жыл бұрын
You should check out Telefunc. It's similar to tRPC but has a more ergonomic api. IMHO
@DB-dk2mj
@DB-dk2mj 2 жыл бұрын
Thanks a lot, man! You do great!
@amanueltigistu8268
@amanueltigistu8268 2 жыл бұрын
Thanks Jack. It's a great video. One thing that I need to know is that tRPC can run at the Edge like in Cloudflare Workers, Deno Deploy, Fastly Compute@Edge, others... Recently I have started using Cloudflare Workers with Solid Start (The Awesome Solid.js Meta Framework) & Deno Deploy with Oak & Faunadb. as a result, the whole thing is fast. Building API's & SSR (with HTML Streaming) at the Edge is Really Awesome 👍😎.
@jherr
@jherr 2 жыл бұрын
I honestly don't know. You'd have to ask the tRPC author on that one. :)
@jasonthorpe3470
@jasonthorpe3470 2 жыл бұрын
Great video as always! I learned something new every time and trpc is so cool! I've always found sharing types with the front and back end such a pain. Not to pick nits though: isn't it the browser that enforces CORS? That's a security mechanism that always mystified me...
@jherr
@jherr 2 жыл бұрын
Yeah, CORS is only required for CSR.
@DanKaschel
@DanKaschel 2 жыл бұрын
The browser enforces requirements established by the API. CORS is the mechanism that allows an API to say it's okay with requests from other origins.
@jasonthorpe3470
@jasonthorpe3470 2 жыл бұрын
@@DanKaschel I wasn't really confused by how it worked, just that it's so easy to write a proxy that enforces a different set of CORS rules, makes that protection useless against all but the least savvy would be API theives. I'd be happy to learn otherwise...
@eplete
@eplete 2 жыл бұрын
@@jasonthorpe3470 an important feature of cors is to protect requests using cookies. If you create a proxy you will have a different origin so the browser won't send the same cookies. If the api doesn't use cookies, then there isn't much security benefit to cors
@bolatbekyeraliyev323
@bolatbekyeraliyev323 2 жыл бұрын
Jack, amazing content and great presentation. Thank you for covering the frontier of dev tools. A quck question: is there any materials in which you explain how to setup concurrently, wsrun and how to handle errors caused by these tools?
@muhamadluthfia2580
@muhamadluthfia2580 2 жыл бұрын
Hell yeah man good work
@JGBSolutions
@JGBSolutions 2 жыл бұрын
Hey really cool vid as usual. I'm picking some new stuff thanks to you. I have two question:s I see that you use ScreenFlow and I like the effects. Any resources to look at to learn more? I want to make nice videos as well. And what do you use to draw on the screen? I saw you were looking down while doing that. Thanks!
@jherr
@jherr 2 жыл бұрын
For drawing i use a Gaomon tablet and Screenbrush. I do all the code work in Screenflow then use After Effects to put it all toghether.
@JGBSolutions
@JGBSolutions 2 жыл бұрын
@@jherr thank you!
@riccardopellegrino5447
@riccardopellegrino5447 2 жыл бұрын
Hi Jack! I'm new to backend development, what do you mean at 22:10, when you talk about "adding a reporting mechanism on top of REST"? thanks!
@jherr
@jherr 2 жыл бұрын
REST is an entity based model. Your model entities like user, product, and order. You can read, write, update and delete individual entities, and also get lists of that type of entity (e.g. all products.) But you can't get a joined set of entities in that model, for example, all the users that placed orders for a give product. That's why people created a REST API and then bolted on a set of reporting APIs to make up for the limitations of the REST API.
@riccardopellegrino5447
@riccardopellegrino5447 2 жыл бұрын
@@jherr got it! 😁thank you for your awesome channel
@inversebrah
@inversebrah 2 жыл бұрын
You're awesome Jack!!!
@Light-nn6hn
@Light-nn6hn 2 жыл бұрын
Please, when u did npx create-react-app, it showed a bunch of option to select such as if u wanna use css or tailwind How do i get that to work on my pc as well?
@abdelhameedhamdy
@abdelhameedhamdy 2 жыл бұрын
Very neat Jack, for those who don't want to expose graphql, is tRPC a good practice to wrap or hide graphql data source ?
@jherr
@jherr 2 жыл бұрын
Yep. IMHO, GraphQL is a good fit for when you have a lot of flexibility on the frontend and the structure of queries may change a lot, or if you are providing a customer API (though that has some issues as well). If you don't fit either of those then something like tRPC is fine because you know the data you need at build time.
@EvanDotJS
@EvanDotJS 2 жыл бұрын
Apparently that router method at 3:55 is deprecated now? Not sure if its gonna break my server or not but we'll see!
@technikhil314
@technikhil314 2 жыл бұрын
Wow this is like prisma but from frontend to backend or cross service calls. Basically remove contract testing.
@amritpalsingh7262
@amritpalsingh7262 2 жыл бұрын
can someone tell me what kind of extension is in the video which shows the text autocomplete highlights in the editor as we type.
@jherr
@jherr 2 жыл бұрын
Github Copilot
@eleah2665
@eleah2665 2 жыл бұрын
Very intersting. Thanks.
@DiegoBM
@DiegoBM 2 жыл бұрын
I kind of get the same feeling that I got when I first saw Redux. I was in awe when I saw the time-travelling feature, but I couldn't help but thinking that it was kind of cumbersome to set-up for the value. Maybe they'll improve the API or the general DX in future releases. All in all, I'm not sure to get the full value of tRPC? Maybe I was so hyped before reaching this video, with so many people singing it's wonders of and swearing by it, that it was easy to feel kind of disappointed.
@SumitYadav-bk3jw
@SumitYadav-bk3jw 2 жыл бұрын
Awesome content Can you share your vs code theme?
@AnkurOberoi
@AnkurOberoi 2 жыл бұрын
Great video! I'm curious, what software/hardware are you using for the on screen annotations with a stylus/pen? It's so seamless!
@jherr
@jherr 2 жыл бұрын
ScreenFlow plus a commodity drawing tablet from Gaomon.
@krishgarg2806
@krishgarg2806 2 жыл бұрын
It looks a lot like how we make graphql servers. What do you think would be better trpc or graphql server if we know graphql, as we can use the graphql schema to generate type safe code on the client using packages like graphql-code-gen
@v333b
@v333b 2 жыл бұрын
Hey Jack, this video is really helpful and has gotten me more interested in tRPC and typescript. One small thing that left me a little confused is that when you connected the api-server with the client, while this works for the dev process, how would this pan out during deployment? The client would not be able to access the api-server package as it only exists in the local env... Would adding the server as a dev dependency yield the same result?
@pieter-venter
@pieter-venter 2 жыл бұрын
Very good question. You not actually importing any code between the 2 apps. Your simply importing types. In production the types are compiled away. Under the hood trpc makes an http call with the route names. So it's not like the files need to be collocated at all. Ps. We been using trpc for over a year now with Prisma and next and we're hiring. Hit me up on Twitter if you keen to join
@jeielmosi
@jeielmosi 2 жыл бұрын
I'm love with this terminal theme. Is this a zsh theme?
@jherr
@jherr 2 жыл бұрын
Nope, it's oh-my-posh.
@jeielmosi
@jeielmosi 2 жыл бұрын
@@jherr what theme is this?
@jherr
@jherr 2 жыл бұрын
@@jeielmosi Night Wolf [black] and Operator Mono.
@tatenda_mk
@tatenda_mk 2 жыл бұрын
So helpful! Thank you
@carlosricardoziegler2650
@carlosricardoziegler2650 2 жыл бұрын
Some examples are using monorepo , right? How can I use it with different repos for front and backend ? Do the app like package ?
@theyreMineralsMarie
@theyreMineralsMarie 2 жыл бұрын
How would this work if the API source is in a completely different repo? What if the API is running and hosted on a different server from where the UI static files are served?
@jherr
@jherr 2 жыл бұрын
You'd generate into a shared npm module, or generate into the server module and have the client app consume whichever shared module you created.
@mmmikem
@mmmikem 2 жыл бұрын
Hey Jack! I'm curious about creating the trpcClient as state here. Why would this be required as opposed to, for example, useCallback? Would this still work? Can you think of any reason to prefer one over the other?
@jherr
@jherr 2 жыл бұрын
Can you give me a time reference?
@mmmikem
@mmmikem 2 жыл бұрын
@@jherr sure thing! 9:54 should do the trick - sorry that'd have been pertinent considering this is from Feb!
@jherr
@jherr 2 жыл бұрын
@@mmmikem Well, it's not a function, so I wouldn't use `useCallback` but you could use `useMemo` if you want instead, though as some folks have said the docs state that in the future React reserves the right to flush memos to recover space. Or you could use a `useRef` for this, but then you'd need to say `trpcClient.current`, which is not exactly a game changer. Frankly you could probably just pull this out of the component altogether and just define it at the top of the file. I'm not 100% sure why I found it necessary to define it in the component here. As you say, it has been a while since I did this video. Lots of interest in TRPC tho!
@mmmikem
@mmmikem 2 жыл бұрын
​@@jherr ah of course - it's the return of the function that we care about. Oddly enough, I'd thought about whether it *might* need to be invoked inside the component if it was relying on hooks somewhere in there. I feel as though, if that works, it'd be the simplest/cleanest option, as it'd be colocated with the RQ client? I'm gonna give this a bash and see! Thanks for taking the time to respond, really appreciate it!
@matheusvictor9629
@matheusvictor9629 2 жыл бұрын
Well another Con agains GraphQL is that it can't choose what it will be sent to the client, cause in tRPC, what you have on your query is what is going to be sent, right?
@jherr
@jherr 2 жыл бұрын
You mean a con against tRPC right? Yeah, that's correct, the payload is the payload.
@pieter-venter
@pieter-venter 2 жыл бұрын
Hi Jack or anyone that knows, what tool do you use to have the nice graphics with the apple logo and node version? Is it a oh-my-zsh plugin?
@demiann4160
@demiann4160 2 жыл бұрын
Thanks Jack! I have my cross feelings about TRPC. Why would anyone would like to make a non-language agnostic API? So if I'm a python dev, I will have to first learn TS and then TRPC to consume the API?
@jherr
@jherr 2 жыл бұрын
It can be accessed just like any other REST API. It's just easier when you use TypeScript.
@Zagoorland
@Zagoorland 2 жыл бұрын
Can you give some tutorial how to style fonts the way they look in your IDE? Also, what's the name of your theme?
@imichael.
@imichael. 2 жыл бұрын
Just FYI: The NPM package for create-mf-app doesn't link to the Github repo
@DB-dk2mj
@DB-dk2mj 2 жыл бұрын
Please - what is your extension for terminal - so it looks cool!?
@jherr
@jherr 2 жыл бұрын
Fig is what I think you are looking for.
@tubenzr
@tubenzr 2 жыл бұрын
Hy Jack, Excellent content as always, but I'm always wondering what is your opinion on NodeRed low-code, because I'm amaze with how NodeRed handle business-flow. can you give me one or two opinions on this. thanks so much Sensei.. 🥳
@Neth91
@Neth91 2 жыл бұрын
i notice a lot of hype about trpc lately but i havent figured out and havent tried it myself yet. is this also beneficial for java backends ? i have very limited fullstack experience and dont know what server this is supporting
@jherr
@jherr 2 жыл бұрын
No, this wouldn't benefit the Java backend world. The idea here is that tRPC is TypeScript on both ends of the pipe, so it makes it easy to define your object types once and use them in both places.
@webdev_telugu
@webdev_telugu 2 жыл бұрын
When he installed dependencies with "yarn", why were there no node_modules created in client and api-server
@bhaveekjain4246
@bhaveekjain4246 2 жыл бұрын
What fish shell theme are you using?
@vincentgauthier2298
@vincentgauthier2298 2 жыл бұрын
hey can you tell me the VS code theme you use? Thanks! Great video.
@jherr
@jherr 2 жыл бұрын
Night Wolf [black] and Operator Mono or JETBrains Mono.
@rcarias78
@rcarias78 2 жыл бұрын
What’s that terminal theme you use. I like that it shows you the full path.
@jherr
@jherr 2 жыл бұрын
Night Wolf [black] and Operator Mono.
@rcarias78
@rcarias78 2 жыл бұрын
@@jherr and how do you get your ZSH terminal to show you the full path
@kiranojha8811
@kiranojha8811 2 жыл бұрын
@@rcarias78 oh-my-zsh probably
@esotomay21
@esotomay21 2 жыл бұрын
How do you setup ur terminal to give you all those pretty icons
@aleksd286
@aleksd286 2 жыл бұрын
so TRPC is Graphql without the additional syntax learning? You can also get your types from Graphql server to the client
@Glinkis
@Glinkis 2 жыл бұрын
You'll have to add a type generation build step for GraphQL though, while tRPC seem to be able to infer the types directly.
@omkarkulkarni3644
@omkarkulkarni3644 2 жыл бұрын
What font do you use in terminal?
@jherr
@jherr 2 жыл бұрын
SpaceMono NF
@waqasrana5734
@waqasrana5734 2 жыл бұрын
you are doing great
@kamiljanowski7236
@kamiljanowski7236 2 жыл бұрын
Did you just import server code into client code? I know... tree shaking and this is just a quick demo and all but... my eyes are burning 🔥
@jherr
@jherr 2 жыл бұрын
At what time marker?
@hassaannoor
@hassaannoor 2 жыл бұрын
tRPC is great but there seem to be a lot of unnecessary complexities. Telefunc is probably a more literal RPC. Would be fun and helpful to see you try it.
@BezzantSam
@BezzantSam 2 жыл бұрын
It is like reading Dostoyevsky and then trying to pick up a pen and write watching you
@asyncxeno
@asyncxeno 2 жыл бұрын
How did you make the terminal like that?
@willbdev
@willbdev Жыл бұрын
Thanks 🐐
@misterhtmlcss
@misterhtmlcss Жыл бұрын
With HTTP2 and the rise of DaaS I do wonder if the value of websockets is as high or broadly useful as it once was. It feels like web sockets is possibly better for niche situations nowadays
@yankee-in-london
@yankee-in-london 2 жыл бұрын
Feels like tRPC's assumption about having typescript in the backend is a major limiting factor for it. I did notice a few Rust crates in early stage but unless other languages are designed to support it ... and TS as a type system is amazing for JS but maybe not what you want to marshal to with other languages. For now, I'd say gRPC's relative maturity and multi-language binding makes it a better choice for most RPC projects.
@jherr
@jherr 2 жыл бұрын
I agree with your issues with TS and other languages. But gRPC is no picnic either. I use gRPC every day and the TS generation is pretty flaky. And some of the data type marshaling has issues. Also you have to proxy gRPC it to web clients. So I end up wrapping my gRPC in GraphQL.
@yankee-in-london
@yankee-in-london 2 жыл бұрын
@@jherr surprised to hear about the marshaling issues with gRPC but I will admit I don't have a lot of hands on with it ... would have thought a solution in the market as long as gRPC would have worked out all of these kinks. Do you use Zod for validation on the gRPC setup? Seems like that would help in assurances for run time type checks.
@jherr
@jherr 2 жыл бұрын
@@yankee-in-london I don't use Zod for that. The generated TS is good types wise. The marshalling thing comes down to number values. If the number is undefined it still returns zero. So I end up hand code special casing every field that could be nullable, which kinda sucks. I should probably wrap it to make it generic... Ah, well.
@DuyTran-ss4lu
@DuyTran-ss4lu 2 жыл бұрын
Great as always
@卡卡西-p7i
@卡卡西-p7i 2 жыл бұрын
How do you type so quick, what vscode plugin you use?
@jherr
@jherr 2 жыл бұрын
GitHub Copilot?
@rallokkcaz
@rallokkcaz 2 жыл бұрын
Reminds me of FeathersJS and Meteor.
@kashnigahbaruda
@kashnigahbaruda 2 жыл бұрын
Thanks!
@BathingAfrican
@BathingAfrican 2 жыл бұрын
I’m tryna transition from fastAPI to gRPC, is there a fundamental difference between the two as to why you’d pick tRPC?
@jherr
@jherr 2 жыл бұрын
Are you talking about the Python fastAPI? If so, then, a big difference would be Node vs Python.
@patite3103
@patite3103 2 жыл бұрын
Could you please update this video using tRPC V10? Thank so much for your valuable videos!
@ogidarmatena
@ogidarmatena Жыл бұрын
how to deploy this project to vercel?
@BHFJohnny
@BHFJohnny 2 жыл бұрын
I wonder why devs decided to create a trpcClient with useState hook. Why not just create it the same way as react query client... I checked tRCP docs, I don't know. I checked your code as changed it, nothing broke, everything still works. Feels like trap, but I think it should be just fine, at least in this case. Maybe it has something to do with async stuff and the new React use hook , I don't know
@housecor
@housecor 2 жыл бұрын
The (obvious) con of tRPC: It requires running TypeScript on the server. So for many teams, that rules it out. That's why GraphQL is so popular - it's a standard that isn't tied to a specific server-side language. But if you're using TypeScript on the server, tRPC a wonderful option that's simpler than GraphQL.
@xamantiwari
@xamantiwari 2 жыл бұрын
Can we use ionic with backend express trpc?
@jherr
@jherr 2 жыл бұрын
I don't see why not.
@ziranshuzhang6831
@ziranshuzhang6831 2 жыл бұрын
I am trying to see how tRPC is different from the regular REST API, and it seems it is nothing different from REST except the name.
@jherr
@jherr 2 жыл бұрын
It depends on what. you mean by REST. REST isn't a standard. It's an "architectural style". And the only specific thing it covers is the basic verbs associated with entities and collections and the hierarchal relationship between them. Generally speaking REST is both incomplete in that it doesn't allow for one query that involve more than one entity or collection at a time, and also incorrectly structured because the hierarchy of the entities doesn't allow for important permutations of queries. I usually see REST coupled with a set of RPC endpoints. And people just call that "REST" when it's not really anything "standard". Every team/project/company just comes up with their own standards. tRPC is a standard (though not as well specified as GraphQL) and it provides easy end-to-end typing.
@ziranshuzhang6831
@ziranshuzhang6831 2 жыл бұрын
@@jherr What I mean is that the things you did in the video, seems like I can do all of them with bare ExpressJS with the same amount of effort, and probably even less amount of code. That's what I am not sure why I need tRPC for my project.
@jherr
@jherr 2 жыл бұрын
@@ziranshuzhang6831 You might not. If you don't think that tRPC adds anything then don't use it.
@chengxiaoxia8046
@chengxiaoxia8046 2 жыл бұрын
- error ``` Error: Debug Failure. False expression: Non-string value passed to `ts.resolveTypeReferenceDirective`, likely by a wrapping package working with an outdated `resolveTypeReferenceDirectives` signature. This is probably not a problem in TS itself. ``` - solution: upgrade version in package.json like below ``` "ts-node": "^10.8.0", "ts-node-dev": "^2.0.0", "typescript": "^4.6.4" ```
@abdelhameedhamdy
@abdelhameedhamdy 2 жыл бұрын
Wundergraph like
You're Doing React Hooks Wrong, Probably
20:11
Jack Herrington
Рет қаралды 64 М.
NextJS to Astro: more control = faster sites
43:28
Jack Herrington
Рет қаралды 61 М.
I Sent a Subscriber to Disneyland
0:27
MrBeast
Рет қаралды 104 МЛН
She wanted to set me up #shorts by Tsuriki Show
0:56
Tsuriki Show
Рет қаралды 8 МЛН
Hilarious FAKE TONGUE Prank by WEDNESDAY😏🖤
0:39
La La Life Shorts
Рет қаралды 44 МЛН
#behindthescenes @CrissaJackson
0:11
Happy Kelli
Рет қаралды 27 МЛН
Why I don't use React-Query and tRPC in Next.js
18:58
ByteGrad
Рет қаралды 104 М.
I Never Want to Create APIs Any Other Way
17:32
Marius Espejo
Рет қаралды 25 М.
tRPC - GraphQL KILLER??!
11:24
Theo - t3․gg
Рет қаралды 100 М.
Is this a better way to build APIs?
9:10
Awesome
Рет қаралды 27 М.
NextJS 12.1 SSR & SSG: Everything you need to know
31:18
Jack Herrington
Рет қаралды 99 М.
10 Signs Your Software Project Is Heading For FAILURE
17:59
Continuous Delivery
Рет қаралды 43 М.
Let's Learn tRPC!
1:26:05
Learn With Jason
Рет қаралды 19 М.
Mastering React Memo
26:56
Jack Herrington
Рет қаралды 138 М.
I Sent a Subscriber to Disneyland
0:27
MrBeast
Рет қаралды 104 МЛН