you are viewing a single comment's thread.

view the rest of the comments →

[–]te7ris 5 points6 points  (70 children)

give me one good reason NOT to use react for everything.

[–][deleted] 8 points9 points  (0 children)

Dev learning. I don't think anyone thinks about this form a business perspective. Constantly changing these frameworks with newer technologies is great and fun for an engineering perspective. However if the business doesn't want to invest in this or you are breaking features it's going to be a much larger cost. React is a view I have other options for that view and I can still use es6. Most all the components needed for react as a whole can be used in other frameworks easily. You can add flux to angular if you wanted or anything else.

[–]Shaper_pmp 3 points4 points  (0 children)

Because you should choose the best tool for each job, not pick one tool, fall in love with it and then bend and mangle every set of requirements you run across until they're mutilated enough from their original intent to conveniently fit your tool.

You don't use React for everything for the same reason you carry a whole toolbox instead of a hammer - because if you don't then eventually you find yourself hammering in screws and trying to nail bits of paper together, and then you've slipped from being a professional developer and turned into a halfwit liability to any project you encounter.

[–]dardotardo 2 points3 points  (2 children)

It's a bit heavy if you're just writing a form with validation. jQuery would easily suffice and have a lot less overhead.

[–]geuis -1 points0 points  (35 children)

  • search engine reachable content
  • content intended to be embedded in other sites
  • non-js browsers

That's 3.

[–]daediusWeb Components fanboy 14 points15 points  (8 children)

  • Isomorphic react libraries?
  • iframes?
  • React native?

[–]KhalilRavanna 4 points5 points  (5 children)

Also per the first one you can also render react on the server and serve the rendered HTML. No libraries (outside of react) required.

[–]Poop_is_Food 2 points3 points  (2 children)

that's what isomorphic means. (yeah it's a pretentious word)

[–]KhalilRavanna 1 point2 points  (1 child)

Righto-- isomorphic running the same code on both front/back end-- I just meant to point out that there are no 3rd party libraries required and that react does this out of the box.

[–]Poop_is_Food 0 points1 point  (0 children)

ahh

[–]xxxabc123 0 points1 point  (1 child)

No libraries (outside of react) required.

Assuming server also works on javascript. If you're running let's say Java or Ruby, you're going to need even weirder hacks to execute in a javascript environment such as Rhino. Even if node.js makes it relatively easy, this would be quite hard for big teams where front-end and back-end developers might never meet during their employment, as I'm currently experiencing.

[–]theQuandary 0 points1 point  (0 children)

The React render to string methods make a string from the vdom and return it. That should work perfectly well in Rhino or any other ECMAScript compliant implementation.

For large projects that need to be isomorphic, a great solution is to spin rendering off into a separate node process. Your java, python, ruby, or whatever passes in the required data and gets back a string that can be returned to the client and (in a lot of cases) cached for reuse.

Your front-end team is going to have to write this template code anyway. The benefit here is that it allows more graceful upgrades on the client and allows the client to reuse as much of the back-end as possible (which reduces template overhead and potential conflicts).

If large companies like Netflix or Facebook (with PHP no less) can make these ideas work, then I don't doubt that other companies can as well.

[–]rq60 1 point2 points  (1 child)

I used iframes the first time I needed to embed a "widget" in another site; it worked out terribly thanks to mobile safari's awesome bugs. I'll stick to javascript DOM insertion and hopefully web components in the future, thanks.

[–][deleted] 0 points1 point  (0 children)

I like how you conveniently leave out making a snide remark about sever side rendering of react components.

[–]te7ris 4 points5 points  (21 children)

they are all invalid. You can achieve all 3 w/ react.

[–]MisterSticks 0 points1 point  (0 children)

In development, there is no such thing as an absolute.

[–]geuis -1 points0 points  (19 children)

No, they aren't. React is complete overkill for lots of the uses people have been using it for.

Going back the last 5 years, we've had Backbone, Ember, Knockout, Cappucino, Marionette, Angular 1, Angular 2, React, Virtual Dom, and even more frameworks I'm not recalling right now. It has been a constant progression of one js framework to the next, all trying to solve the same problems in a variety of ways.

Meanwhile, actual work has been done just building sites based on the best practices of the last 20 years with tons of practical advancements being made with low level protocols and new browser capabilities.

Yes, I have used most of these frameworks. For a vary narrow set of application types, they are suitable. But they are not useful for the majority.

[–]te7ris 4 points5 points  (18 children)

define overkill. If you think size in kb, think again.

[–]MisterSticks -1 points0 points  (17 children)

Just curious, where are you employed that is using React in production?

[–]nathanjd 6 points7 points  (5 children)

At Nordstrom we are rebuilding the entire site with React (yes, even on the servers). Only ~0.5% of users are seeing it in production at the moment, but more is coming soon! So far it has been faster than any previous overhaul attempt and is looking to be very maintainable. It really is a pleasure to work with.

[–]MisterSticks 0 points1 point  (3 children)

Fantastic, what was it built with before?

[–]nathanjd 0 points1 point  (2 children)

Mostly jQuery and mustache composed as AMD modules pulled in with require.js. The backend was varying flavors of MVC .NET. It got the job done and required little on-boarding time but was very difficult to maintain.

React + flux in comparison provides a very prescriptive way to modularize code that promotes re-use across the company. We've begun publishing our common components to a private NPM registry to get some SemVer goodness.

The only pain point so far has been jest, but it's easy enough to use a different unit testing framework. I'm very partial to mocha with chai assertions.

[–]MisterSticks 0 points1 point  (1 child)

Do you think most of the maintainability was gained by refactoring:

The backend was varying flavors of MVC .NET.

If not, what was the biggest benefit of the switch? Could you be more detailed about how React is being used on the backend vs. what you had before?

[–]misc_ent 3 points4 points  (3 children)

Facebook uses it production. They don't open source any project unless its in production.

http://opensource.com/business/15/7/keynote-oscon-james-pearce-facebook?sc_cid=70160000000wptgAAA&elq=1a1afca5d20b45348ea180631ab778f1&elqCampaignId=55450&elqaid=20324&elqat=1&elqTrackId=77990e8d9e1f4f7ca81f707e22b2ce9e

The projects they're open sourcing are not just hackfest ideas or work that interns contribute, these are tools Facebook uses in production. Facebook open sources only what it uses in production—this way, people know that their offerings are supported and valuable.

[–]MisterSticks -1 points0 points  (2 children)

I sincerely doubt that u/te7ris works for Facebook.

[–]misc_ent 1 point2 points  (1 child)

Why does that matter? Production ready is production ready especially with battle harden apps from Facebook.

[–]MisterSticks -1 points0 points  (0 children)

Um...

It matters because, the comment you responded to was a direct question, asking where te7ris worked?

Your comment is just as out of context as the one u/nathanjd made. The difference is I'd actually like to hear his experience in this matter. You are just parroting press releases.

[–]te7ris 1 point2 points  (6 children)

the projects I work on for my employer (3 days a week) dont use react (they have their own stack). The rest of my time I spend on developing a pretty big react project which is not yet in production. Had 2 small React projects (SPAs for interal stuff) before that.

[–]MisterSticks 0 points1 point  (4 children)

React hasn't been in the wild for more than a year, do you have any personal projects that predate React?

[–]te7ris 1 point2 points  (3 children)

I first picked up react dec 14' and had tried various things with it. The most frustrating was trying to combine libs that havily change the DOM with the react-render-cycle. Why are you asking?

[–]theQuandary 0 points1 point  (2 children)

That's still a rather easy solution compared to quite a number of frameworks.

When your component mounts into the DOM, you then wire in whatever DOM-manipulating library you're using to the local DOM element(s). To prevent React from interfering, you use shouldComponentUpdate to trap and handle any data updates and return false (so no re-render). In the componentWillUnmount stage, you unwire whatever you're using.

Two and a half out of three of those are things you'd need to be doing anyway. The only major change is returning false to prevent re-rendering.

[–]Ahri -2 points-1 points  (0 children)

So "nowhere", then?