Hacker Read top | best | new | newcomments | leaders | about | bookmarklet login

Actually reactive UIs trace back to Haskell and FP reactive programming concepts.


view as:

Sure, I’m familiar with Conal Elliott’s work. But other than its “elegance”, I don’t hold reactive programming in particularly high regard, especially when implemented on top of non-pure languages. I consider FRP a “clever” technique - and while “clever” techniques make programming a fun puzzle, they can be detrimental to performance and end-user experience.

We have a finite cleverness budget; if you spend it on your code, then your product will suffer. If you build cleverness into the platform SDKs (hello SwiftUI! hello J2EE design pattern hell!), then every product on your platform will suffer.


J2EE has stopped being a thing in 2005, and I am quite found of JEE, so I like to use my cleverness budget.

As for SwiftUI, I guess the only issue it the current state of its tooling, as I have heard it still is found lacking.

Yet if one listens to iOS podcasts everyone is raving about it.


I haven't seen any cleverness in reactive code that one wouldn't encounter in a non-reactive code base. It is true that one may need to learn new abstractions, but a more imperative coding style requires lots of glue code, much of it having inconsistent quality. You'll end up needing ramp-time no matter how you go. Building UI involves the same problems and trade-offs whether using reactive programming techniques or not.

Conal Elliott's work, while super interesting, does not cover the entirety of reactive programming. I found this[1] write-up to be helpful in defining what reactive programming is and it's value. The author is a member of the team working on Swift Concurrency.

And SwiftUI is compatible with anything from UIKit, so it actually doesn't hold anyone back who wants to try to do something non-trivial. If you watch the demos, particularly from the most recent WWDC, you'll see it actually makes quite complex behavior much more doable. Does that reduce the value of esoteric framework knowledge? Perhaps it does, but that means engineers now have more time to spend on the product not less.

[1]https://www.oreilly.com/content/why-reactive/


If you mean FRP by Conal Elliott, then not really, it's an almost completely different branch entirely.

Legal | privacy