Over the years REST APIs have shown to be too inflexible to keep up with the rapidly changing requirements of the clients that access them.
GraphQL presented as a revolutionary new way to think about APIs, where instead of working with rigid server-defined endpoints, you can send queries to get exactly the data youβre looking for.
Do you prefer GraphQL over REST in your own projects?
Oldest comments (17)
right now its only meant for JS or Js frameworks especially React.
However, from Using it in Laravel using the lighthouse-php for laravel works fine for me and I am exploring it more. Then only I can be assure that it is good to use GraphQl over REST.
REST is everywhere so I'm quite used to it. A few days ago I tried playing around with HashNode's GraphQL API and to be honest I struggled. To me, it looks like that the learning curve for GraphQL is much steeper, so I'm still a fan of good old REST!
Hashnode's API was my first contact with it too π I must say I love it and it reminds me of working with DOM in the browser π
Nice! I actually got stuck with the new post creation, did you manage to get it to work?
I was working with their API the other way around - for fetching data. But for posting, I believe you have to make a mutation, as shown in this example to create a new story.
For further assistance, I would recommend their Discord server. Together we already found a bug in their API by discussing particular ways of retrieving data.
Thanks, sounds good! I will try it out! π
I have experience with both GraphQL and REST, and while I appreciate both I do think the dynamic capabilities of GraphQL architecture makes it more flexible for complex data structures. It's harder to fit a complex data structure in REST in an efficient way and create a fast API in my experience. I do think GraphQL lends itself to programming efficiency because it can handle a lot in one query. But this is also coming from the API testing perspective, not a development perspective :)
No. It's complicated.
In my most of scenarios, it's good enough to use the normal RESTful API and it can resolve most of requirements.
I'm pretty skeptical of a large GraphQL API's performance over time, but have never worked with one. I'm starting a new job in December whose primary api is a flask based graphql one tho, so I'll find out soon!
I've read about some other devs being skeptical about using it on large projects, too π Tho, it is a widely-used tool nowadays, and every situation you could possibly face should already be backed up by some workaround/best practice π
GraphQL with gRPC is the best approach if you really want to escalate the application you build, there is no matter to discuss here. More performance (gRPC, as you don't need to parse JSONs and the weight is smaller), the ability to ask for some extra data from the front without the need to make changes to the API itself and so...
REST API, bcoz what to do if data needs some processing!
Client directed security API (CAC or SmartCard driven).
I prefer REST since its easier to work with on small projects. If you have a really complex app with lots of fields on the models I can see it the appeal of graphql though.
I call bias and shallow the arguments against REST and in favour of GraphQL.
There is no absolute best, each project presents its architectural challenges. these challenges are going to define the best tools for the project, not favouritism or personal preference.