Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Has Redux's Time Come and Gone #775

Closed
ghost opened this issue Sep 22, 2015 · 50 comments
Closed

Has Redux's Time Come and Gone #775

ghost opened this issue Sep 22, 2015 · 50 comments

Comments

@ghost
Copy link

ghost commented Sep 22, 2015

My team and I have spent a lot of time learning redux and have started to build a new application with it. I was listening to @gaearon on The Software Engineering Podcast found here http://softwareengineeringdaily.com/2015/09/18/flux-redux-and-react-hot-loader-with-dan-abramov/. At the 50 minute mark @gaearon said "but of course declarative data fetching is the future and redux does not offer you declarative data fetching so redux has past".

Should I build anything with Redux or should I be moving on to Relay / GraphQL?

@ronag
Copy link

ronag commented Sep 22, 2015

#464

@gaearon
Copy link
Contributor

gaearon commented Sep 22, 2015

Many people are pretty happy with Redux. You should ask around—I'm not really qualified to answer this question. I'd say if your app is very data-heavy a la Facebook (many nested entities with complex relationships) it's a good idea to invest in a GraphQL backend and learn Relay. I've only heard good things about it.

Redux of course is more explicit and doesn't solve declarative data fetching for you. There are attempts to integrate Redux and GraphQL but I can't evaluate them against Relay—I know too little about it.

Redux is much lower level than Relay, and is no more “past” than plain JS objects and functions are “past”. Relay is a framework, and Redux, sans the sanity checks, is ten 10-liner functions, so it shouldn't be a surprise that they have different scopes. Pick what works best for you and let us know.

@RickWong
Copy link

Declarative fetching of GraphQL is amazing, top-notch. However Relay still has a HoC API mainly, which isn't declarative per se. If Relay would offer a more flexible API, uncoupled from the component tree, then a proper Redux-binding could be written?

@mattapperson
Copy link

I think they are 2 types of systems that solve 2 distinct issues.
This ticket is like carpenters asking if the time of the hammer has passed.
graphql based systems I would argue are an over engineered solution for many apps, conversely apps with complex data structures are most likely under engineered if built using redux.

@gaearon
Copy link
Contributor

gaearon commented Sep 22, 2015

graphql based systems I would argue are an over engineered solution for many apps, conversely apps with complex data structures are most likely under engineered if built using redux.

Good way to put it; that's how I feel about it too.

@mattapperson
Copy link

@gaearon keep up the good work with redux! One of the best tools going! I am using it in 5 large apps and 2 small ones at my company and loving it!

@vojtech-dobes
Copy link

@gaearon keep up the good work with redux! One of the best tools going! I am using it in 5 large apps and 2 small ones at my company and loving it!

💯

@oriSomething
Copy link

i think their not the same:

  • relay - for solving data fetching management from the server
  • redux - for solving state management of application

many complex applications contains state which is not related to the server that you'll need to manage. i'll argue that if you'll use relay, you'll see yourself in the end need redux as well. according to the opposite, relay seems like a very nice boost but only for server related stuff

@IwanKaramazow
Copy link

Question is how does Relay relate to flux inspired design patterns? Where does Relay end, when do we need Redux? Is Relay Flux 2.0?

The Todo Relay example: does it render redux obsolete?

@aphillipo
Copy link

Maybe there is a way to tell your reducer how to map itself to and from GraphQL and when? Not saything that isn't complex but what is the simplest way to make that make sense.

Need to learn more about what Relay is. It's not a couple of hundred lines of code that's for sure!

@gyzerok
Copy link

gyzerok commented Sep 22, 2015

@oriSomething You are not quite right. Relay solves a lot of state management too.

@oriSomething
Copy link

@gyzerok i've meant client side application state

@gyzerok
Copy link

gyzerok commented Sep 22, 2015

@oriSomething Yes, I'm talking about client-side application state

@oriSomething
Copy link

@gyzerok i've must missed it. can you give me a link about this?

@gyzerok
Copy link

gyzerok commented Sep 22, 2015

@oriSomething there is no special link because Relay manage it implicitly. Maybe you can try to watch FB talks about Relay. They talking about how Relay solves cache problem. Client-side application cache = state. I do not remember definite talk, sorry.

@gyzerok
Copy link

gyzerok commented Sep 22, 2015

@oriSomething the only place developer should do some explicit state management is here.

@oriSomething
Copy link

@gyzerok ok, so in that case, is there a state management that isn't related to the server that relay does? as far as i understand it doesn't, or is it?

@gyzerok
Copy link

gyzerok commented Sep 22, 2015

@oriSomething If I understood you correctly Relay do all things about data normalization on the client and merging data from queries into single store.

@IwanKaramazow
Copy link

@oriSomething yes, it does=> https://facebook.github.io/relay/img/Guides-Containers-HOC-Relay.png
Check: https://facebook.github.io/relay/docs/guides-ready-state.html#content

Only if there's insufficient data on the client, Relay sends a request to the server for more data.

@gaearon
Copy link
Contributor

gaearon commented Sep 22, 2015

Redux is much lower level than Relay, and is no more “past” than plain JS objects and functions are “past”. Relay is a framework, and Redux, sans the sanity checks, is ten 10-liner functions, so it shouldn't be a surprise that they have different scopes.

So I made slim-redux.js just for fun—a version of Redux without comments, developer warnings and sanity checks. It passes all the essential Redux tests (except the sanity check tests), and it's 99 lines 😉 . This should seal my point that Relay and Redux are tools with wildly different scopes.

@oriSomething
Copy link

@IwanKaramazow i think i wasn't clear enough, what i'm trying to say, is not all data is about the server, there is a data which is not related to the server to manage, and i truly don't think relay is the go to "tool" even if it can to manage this data

@IwanKaramazow
Copy link

@oriSomething can you give an example?

@mlusetti
Copy link

Fully agree @mattapperson . Everything comes down to the definition of complex, or better, to where each individual recognize a "complex thing"

@johanneslumpe
Copy link
Contributor

@IwanKaramazow I think @oriSomething talks about client side form state for example

@gregziegan
Copy link

I moved from Redux => Relay because of GraphQL. Mostly all the resources in my application were hierarchical. They naturally made sense to be nested entities. Keeping a cache of these models in Redux was amazing. I had a sane view of my data and could quickly iterate with the awesome redux-devtools.

But without GraphQL, I had to do several round trips to map remote resources to the redux tree.

  1. /resource1-list
  2. /resource2-list?resource1=
  3. /resource3-list?resource2=

Obviously this is a problem with REST, not Redux. Had I seen some Redux-GraphQL bindings earlier, perhaps I would be using those. Adopting Relay changed very little in my application. Instead of @connect I am using Relay.createContainer. Both products have the same vision of architecture with differing APIs. I wrote a quick post on this.

@juhaelee
Copy link

I am currently using both redux and relay/graphql and although relay is amazing for data fetching, i can see myself always using redux. I currently use redux for 2 reasons and I can see myself finding more reasons in the future

  1. Miscellaneous state that needs to be shared between components that do not live in the database
  2. Form prep. I actually have one part of my application where I have a toolbar component that has a submit button, and a panel component that holds all my input fields. When I type in the form, I debounce my input into a "form reducer" stored in redux so that my toolbar can have access to the data before I submit.

Also, redux devtools is awesome.

@TYRONEMICHAEL
Copy link

Man oh man. I have been reading up on Relay today, and I have to admit the code is not easy to read nor is it easy to understand. I looked at a few examples of Redux and I was able to grasp the core concepts by just reading the code.

The tutorial or the Todo example seem anything but elegant. I think React and FLUX pride themselves on being simple. I don't get that feeling from Relay as of yet.

@timdorr
Copy link
Member

timdorr commented Sep 22, 2015

Given Relay's heavy ties to React and relative overkill in complexity for most apps, I've been more keen on Falcor lately. In fact, because of its promise-based interface, it fits in really nicely with how you do most async behavior in Redux. And because its decoupled from React, I can use it everywhere in my app more easily. Also, server-side rendering isn't fully baked yet, which is a non-starter for me.

I'm also liking react-resolver, which is sort of akin to a "Relay Lite". That one may end up being best for very simple projects or ones that rely on third-party REST APIs.

@jonathan
Copy link

@timdorr Have you tried storing all of your state in Falcor? Having your reducers use a Falcor object, for example.

@timdorr
Copy link
Member

timdorr commented Sep 22, 2015

Not yet. I'm still in experimental mode with it and I've got bigger fish to fry on my projects, so I haven't given it enough attention yet.

@volkanunsal
Copy link

I've played around with Falcor, and I'd highly recommend it. In fact, I'm working on integrating a Redux app with a Falcor backend right now. It doesn't give you the query aggregation of Relay, but it has a very sophisticated cache layer in its client library that prevents overfetching. I think that might be good enough, but time will tell.

@JasonBenn
Copy link

@gaearon how does writing a React web app with declarative data fetching compare to writing the same app in Elm?

Seems to me like the chief difference is that data fetching is more declarative with Relay & GraphQL (Elm asks you to specify a URL, and it's up to you to sort through the data that comes back), and everything else is more declarative in Elm.

Actually, it seems like the Elm ecosystem could benefit from a port of Relay/GraphQL.

@gmmurphy
Copy link

In regards to query aggregation, there's the Model.batch method. It takes either an interval (in milliseconds) or a scheduler but, I'm not finding much documentation on schedulers.

If you don't mind me asking, how are you integrating Redux and Falcor? All my attempts have left me frustrated.

@morenoh149
Copy link

I'd also be interested in seeing a redux Falcor example. I've read all the Falor docs and agree it's much simpler than relay/graphql. Albeit less powerful.

@panayi
Copy link

panayi commented Dec 14, 2015

For anyone wondering about the relationship of Redux with Relay, and whether it makes sense to use them together, see: facebook/relay#114

The gist is that Relay will eventually handle data from multiple sources (backend, local ephemeral data, etc.), so it replaces other Flux implementations you may be using.

facebook/relay#168 (comment):

Note that Relay is an implementation of the Flux pattern (can Flux replace itself? ;-).

@acdlite
Copy link
Collaborator

acdlite commented Dec 14, 2015

We're using both Redux and Relay heavily at OpenGov. It's true that since moving to Relay, our reducers/ folder has gotten far smaller. However, we've found that Redux is still quite useful for application-level, local state management. Perhaps one day Relay will supplant it in that area, too. But as @josephsavona put it once, the "Redux architecture" is really just... functions :) Even if one day you move on from Redux the library, you'll likely continue to use immutable state updates, reactive data flow, reducer functions, etc. for the forseeable future. That's the valuable part of Redux IMO, not necessarily the <100-line library that exists in this repo. (Oh, and the community, of course.)

I'd say if your app is very data-heavy a la Facebook (many nested entities with complex relationships) it's a good idea to invest in a GraphQL backend and learn Relay.

Agreed, but I'd argue GraphQL + Relay is a good investment even for modestly-sized apps, especially for new projects that are starting from scratch.

@skosch
Copy link

skosch commented Dec 15, 2015

What do you guys think of https://github.com/gyzerok/adrenaline?

@valle-xyz
Copy link

Not exactly fitting, because it doesn't use Relay, but what do you think of this opinionated full-stack approach out of the Meteor Community? https://github.com/mattkrick/meatier

@idibidiart
Copy link

Only a deep architecture like GraphQL/Relay or Datomic/Om.Next can solve the object/relational impedance problem... Here are my thoughts -- feedback appreciated.

GraphQL/Relay: The End of Redux? (Perhaps?)

@stubailo
Copy link

Looks like there are a lot of people interested in this topic (Relay/Redux, GraphQL, and reducing complexity) I'm working on a design for a simple yet functional GraphQL client that will play very nicely with the Redux approach to app state.

Curious what people think about this set of design principles: https://github.com/apollostack/apollo-client/pull/7/files?short_path=83772ba

@webdif
Copy link

webdif commented May 1, 2016

Just adding my 2cents here: I don't think there is an end to Redux. It's simple and beautiful, and sufficient in many cases. The JS ecosystem is so fast and hard to keep up, and Redux, like React in some way, is a milestone on which we can rely for some time. We just cannot evolve our workflow every month (or at least, I can't), and I think Redux is a really a good option right now. Relay (and data fetching in general) is just not required on many projects…

@likeabbas
Copy link

@gaearon it has been a few months since you made this post, and you just gave a talk on Redux at a React conference. Where would you say we are now in terms of GraphQL integration with Redux compared to Relay/, or perhaps a combination of all three?

@stubailo
Copy link

@likeabbas if you're looking for GraphQL-Redux integration, try Apollo Client: http://docs.apollostack.com/apollo-client/index.html

We don't have 100% feature parity with Relay yet, but we are getting close.

@license2e
Copy link

@gaearon to echo the question from @likeabbas : "Where would you say we are now in terms of GraphQL integration with Redux compared to Relay/, or perhaps a combination of all three?"

@josephsavona
Copy link

josephsavona commented Nov 2, 2016

A couple brief thoughts. Redux is a generic framework that provides a balance of just enough structure and just enough flexibility. As such, it provides a platform for developers to build customized state management for their use-cases, while being able to reuse things like the graphical debugger or middleware. That use case doesn't seem likely to go away, so rather than "has Redux's time come and gone", perhaps a more interesting question would be: if you are building a GraphQL client, does it make sense to build on Redux?

To which I would answer that it isn't clear that there is one right answer. Building on Redux may benefit from integration (shared tooling, shared data), while building a custom approach is more work but allows more domain-specific tooling and may enable better performance. As with many things in software development, it depends on the use case!

@markerikson
Copy link
Contributor

@josephsavona : that is a great summary of Redux! We may have to steal that for the docs somewhere :)

@stubailo
Copy link

stubailo commented Nov 2, 2016

Yeah the title of this thread is not optimal, and it seems like the question has been kind of exhausted. Perhaps it's time to move the discussion somewhere else.

@morenoh149
Copy link

morenoh149 commented Nov 2, 2016

>.> lock the issue

@timdorr
Copy link
Member

timdorr commented Nov 2, 2016

I'll just close this out. Not sure if any resolution is to be had anyways. Redux works for some people and that's good enough for me.

@timdorr timdorr reopened this Nov 2, 2016
@timdorr timdorr closed this as completed Nov 2, 2016
@reduxjs reduxjs locked and limited conversation to collaborators Nov 2, 2016
@timdorr
Copy link
Member

timdorr commented Nov 2, 2016

Whoops, wrong button. Sorry about that 😄

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests