Facebook?
Why would anyone seriously consider using a Facebook toolkit for anything that didn't need to access Facebook? Could you ever trust it not to steal your customers' data, if not today then in some future update?
Facebook's cross-platform open-source mobile framework React Native lived up to its marketing hype for Walmart Labs as the US shopping giant deployed the software last year. However, the retail goliath hit a wall when it came to people. "The marketing spiels of React Native turned out to be true," said Alexander Grigoryan, …
Assuming that you want to code in JS, and that you want to use a GUI framework to do so, React is one of the more mature ones and has a a sizeable developer following. FB is the originator, and that's about as far as that goes.
React's open source, anyone can scan the libs for mothership calls - it's not hosted. FB (which I don't use), for all its sins, has issued some interesting stuff like this, GraphQL and the Open Compute Project.
Personally, I don't care much for React because it's based on mashing HTML into JS using something called JSX, which makes my eyes bleed. Talk about ignoring what decades of software experience has taught us about separation of concerns ;-) I wonder if that's not what turned off those native devs.
This is JS/JSX file, with HTML lovingly embedded into JS:
return React.createElement('div', {className: 'shopping-list'},
React.createElement('h1', /* ... h1 children ... */),
React.createElement('ul', /* ... ul children ... */)
);
Other choices include:
- Angular, from Google, another noted privacy activist. But Angular 2 pretty much threw away all compatibility from A1, making it a bit hard to trust. And it's also quite complex.
- Vue.js, which I prefer myself. Originated by one main dev and without a major corporate sponsor (heavily used by Alibaba however). It's a pretty clever library, simple and a lot less enterprise-y than Angular or React. At feature parity, or near-parity at least for some use cases, simplicity has a quality all its own, IMHO. Vue's native support is a bit weak, from what I understand.
- and a bunch of other contenders like Ember, Backbone, Stimulus, etc... (I agree with @Simon's framework a week quip).
And, yes, in advance, I deeply apologize to all those that feel that coding in JS, even for web pages, is the work of Satan, the root of all evil, kills puppies and is directly causing global warming.
My coat.
I don’t pretend to be all that good at JS. I did persevere quite a while doing some semicomplex UI code with plain JS + jquery + Bootstrap. An app, basically, with dropdown menus, pick lists etc that then forwards requests to a Django server that is the real brain. Most actions mean page refreshes, not in-page AJAX. Not an SPA. No module loading, except via require.js.
It’s bloody painful, hard to test, extremely unproductive and buggy. Switching to Vue + Webpack/JS6 (but could have been something else) was a massive improvement. Cypress.io on the testing side: much better than Selenium.
Yes, JS frameworks and tooling are a frustratingly fragmented and moving target. And, JS, IMHO, has too many flaws to be a great choice of backend language any time soon. But, if on the web UI side and past a minimal level of complexity, let's not fall into the trap of romanticizing plain JS without build tools (to handle JS6/modules).
It's not like old-schooling C or assembler, much more like hanging on to VB6. YMMV.
Which is to say, just plain old built-in DOM.
And if you need to do that twice, put it in a function, like mother told you to.
That's what I've done for personal and academic work.
However, for non-trivial web-based applications ("RIAs"), you soon find that "put it in a function" becomes "create a fairly extensive Javascript library or framework". That might still be the route you want to take, but framework design and implementation is a rather different skill set than UI development.
Of course there will be people who are good at both, but they're rare. And that's fine - there's no particular reason why someone should be capable in both of those areas. There are plenty of things for people to be good at.
So you're either allocating a rare resource, making the team larger (so you can have both library/framework developers and UI developers), or turning to an outside source for one of the pieces. And since UIs tend to be application-specific, it will usually be the Javascript framework.
I'm not particularly fond of any of the Javascript libraries or frameworks I've seen, aside from some very obscure, limited ones developed by comp.lang.javascript language lawyers years ago. But I understand the economic forces driving the use of the open-source and commercial ones.
Shock horror: You announce that you are changing to something an employee doesn't know and he doesn't like it. This comes down to people being scared for their jobs. It's a universal reaction to a change which could make them (or at least some of them) redundant. Especially, in this case, because there are more JS devs willing to work for less money than native mobile devs (with no comment made about their abilities).
I read this story entirely differently.
Bosses spot that divergence in platforms costs extra money. Decide to introduce mediocre middleware to minimise cost. Developers are upset that they'll have to work in a poorer environment, working on a worse product. Money is saved, so bosses use their platform to write the first draft of history: that everything they wanted is definitely a success, and everybody else was wrong.
Except he admits himself it doesn't scale, they had to write their own framework to interact with non-React bits of the codebase, React components created warnings and errors and they didn't want to convert to React 100%. Sounds more like it doesn't live up to the hype but the CIO forced the change through despite the dev's protestations anyway.
It's designed to provide benefits like the ability to reuse React Native code alongside native platform code, over-the-air updates (rather than through the App Store or Google Play) and shorter development and compile times.
OK. Maybe I am worried. Firstly does this not break the terms of service of the mobile app stores? And if not, why not? Surely the point about having a curated app store is to protect the user from dodgy software (as well as to protect Apple and Google from competition they don't like...). But if you can launch a legit app that gets approved, and then update it without approval - then what's the point?
Oh and Facebook wrote it. So it will be both designed to hoover up all the data it can get, and then spaff as much of it round the internet as possible.
What could possibly go wrong?
I think there may be two kinds of development innovations, whether these are new languages, new frameworks or even resource kits.
One kind, which might be described as traditional, is what you get when someone realises that something new is needed, or has become achievable and will be useful, so they invent a new language or whatever. If they are right about the opportunity, and the new thingy performs well enough, it gets adopted and sees some success.
The other kind, which appears to be a new phenomenon, is when a corporation decides that it wants to entrap yet more wallets in its ecosystem, and builds a new shiny thing, with an attractive interface and a shyteload of marketing crud, to allow folks to do whatever they were already doing but without any fundamentally important improvement.
Possibly I am being a little cynical. But these days every time one of the net giants emits a New Thing, the first thing you look for is: where are the sticky patches, the snares and the traps, the clever little dependencies designed to draw you inexorably in, get you hooked so that privacy and wallet can be sucked dry?
I'm getting old ....
"60 per cent of orders through Walmart's grocery app come through mobile devices." - the only thing I use my phone for in a store is the "Keep" list, my shopping list. I've tried searching for/looking up stuff on my phone but it's generally a disaster ... the native store apps in every store continually try to direct me to something I don't want or need, and rarely actually know where anything is located in the store.
When 60% of orders come via mobile devices then you know that shopper grooming works - I'd expect that with Walmart customers.
Some weeks back my wife ordered something online from Walmart with in-store pickup (as they're the only store in the area that carries that sort of thing - when we're at our other house, with other choices for department store, we avoid Walmart).
The order came in, we went to the store - and then she had to download and install the Walmart app because it was the only way to release the order to us. They had a couple of in-store kiosks but, mirabile dictu, neither was working.
After we picked the order up she deleted the app. Strangely, this experience did not endear us to Walmart.
"It's designed to provide benefits like... ...over-the-air updates (rather than through the App Store or Google Play)". So you won't be able to put your app in either store if you want to offer direct OTA updates, since both forbid that.
It's probably quite easy to automatically spot apps compiled from react native too...
Apparently Apple allows CodePush (which is what Walmart is using).
https://github.com/Microsoft/react-native-code-push/issues/748
"Apple’s guidelines explicitly permit you to push executable code directly to your app, bypassing the App Store, under these two conditions:
* The code is run by Apple’s built-in WebKit framework or JavascriptCore
* The code does not provide, unlock or enable additional features or functionality"
"the lure of a cross-platform option" - cross platform for Apple & Google serfs perhaps, but not for the rest of us. The web was conceived to be a true cross platform solution - usable even by the blind if coded correctly. "Native apps" is just a way to trick people into leaking more personal data than the given use-case calls for.
Meanwhile, facebook's shares have plummeted 20%, shrinking their cap by a headache inducing $120bn - the largest such drop in corporate world history. Perhaps worth a mention, el Reg?
And with poetic timing this coincides with the release of the false and misleading "Vote Leave" ads run on the shite by AIQ, including some rather sneaky phising methods. Perhaps worth a mention, el Reg?
Or are you just bored talking about them?