The results as always make for an interesting read.
WOW, finally. Iâve waited for too long.
Meteor isnât doing that great in the results⌠clearly whoever runs that survey is biased against it!
(But seriously: I think itâs a shame that Meteor suffers from poor perception outside the community, and that MDG doesnât seem to be doing much about it)
I posted this somewhere:
State of Javascript in 2018
Summary:
- male dominated
- ES6 has been established with Typescript continuously growing
- React and Vue have been growing while Angular plateaued with more JS devs leaving it
- Redux is the established state management layer with high interest in GraphQL as the data layer
- Express is the established node framework and Meteor getting less interests from developers
- Mocha and Jasmine have been established (slight decrease) and Jest growing
- React Native and Electron has a lot of interests while Cordova and Ionic are getting less
Its a very painfull fact indeed. Unfortunatly most programmers are âdo it yourself kiddiesâ that are more focussed on coding than on generating value.
Really awesome work on the state of javascript, I really love the design and overall experience.
For Meteor and backend frameworks in general, it seems most JS developers donât like frameworks at all, none of them are doing well, in fact some frameworks from walmart, uber, etc didnât even trend. But what is interesting about the Meteor stats specifically is the high number of heard of it and not interested (50%!), I bet those folks encountered some of the FUD articles that where written in 2015 dismissed it and have no idea what changed in Meteor since then.
Here is a quote from one of my favourite authors pointing out the importance of fiction, stories and marketing:
Homo sapiens conquered this planet thanks above all to the unique human ability to create and spread fictions. We are the only mammals that can cooperate with numerous strangers because only we can invent fictional stories, spread them around, and convince millions of others to believe in them. As long as everybody believes in the same fictions, we all obey the same laws, and can thereby cooperate effectively. By yuval harari
And the fiction around Meteor out there is not doing it much favour so it seems.
Hi Alawi.
I use Meteor for 95% of my work. I think its advantage is the simplicity of learning. But once you get past the basics, it does have a few gotchas which are annoying for me, primarily in Blaze.
- what is âthisâ: in an onCreated(), onRendered(), onDestroyed(), helpers, and events.
- where is my live context data? this data or Template.currentData()?
- where should i be dealing with security? front-end, methods?
- what the best way of merging reactive joined data.
- how do I subclass templates?
I have my head around these issues, and they are not a problem for me, as thatâs part of the 2nd level of learning Meteor, but I think it may have thrown a lot of beginners off.
I understand, but two points in respond to that:
- Meteor is not Blaze, we use Meteor without Blaze
- I used both Blaze and React and I can assure you that React has was way more gotcha then Blaze ever did
The stats says the 50% heard but didnât even try so they donât even count as beginners.
Things I like the most of MeteorJS are:
- Easy to start
- Builtin build tool.
- MongoDB
- Works with React
- Minimongo (easily sort, filter, cache)
- Methods with DDP rate limit
- Subscribe, for real time data (must be careful)
- Server render for SEO
I only build some small/medium websites, those are enough.
In the comparison
Years of experience breakdown for developers who picked âused it, would use againâ for a given option.
Has Meteor the highest rank among devs > 20 years experience (even if the absolute value is low with 9%) and the second highest ranking for devs with experience between 10 and 20 years.
This is something that stands more important to me, than seeing it in the âavoid - low usage, low satisfactionâ corner.
Considering this fact, I wonder how a tech gets this label / summary if well experienced devs used it and would use it again!? This raises concerns about the way they evaluated the poll.
As already mention (and reflected in the poll) the biggest issue is IMO the low public relations / marketing of the framework.
Edit: Most interesting fact:
Most disliked aspects of Meteor among developers who picked âused it and would not use againâ.
Diminishing momentum/popularity
compared to
Most disliked aspects of Express among developers who picked âused it and would not use againâ.
Clumsy programming style
Thatâs an interesting catch as well, indeed it seems to have the highest ratio of experienced developers relative to beginners.
Exactly.
The sad part is that this is a relatively low-hanging fruit compared to the amazing technical work that has already been put into Meteor over the years.
For example you could rename Meteor something like âApollo Buildâ or âApollo Kitâ and brand it as an all-in-one back-end for GraphQL apps (basically what Iâm trying to do with Vulcan). I can understand MDG not wanting to split their focus, but itâs still a little bit sad to think about what couldâve beenâŚ
Exactly, I made similar suggestion to rebrand Meteor to Apollo Build in thinking about Meteor 2.0.
Technically, the closest thing that comes close to Meteor, at least in mind, is Uberâs fusionjs but even that doesnât have Meteorâs maturity or the feature list.
Thatâs interesting indeed. Iâve been thinking for a while that Meteorâs main problem is not the tech, but the marketing. Thereâs no clearly definable value/prop. It just has well thought out answers to problems experienced developers know theyâll run into. Itâs an interesting problem to try and solve.
(Also, Meteor needs a better story on Windows!)
I for myself understand Meteor as a framework for apps, where realtime multi user interaction plays a crucial role. I donât see other solutions that come close to helping me realize projects / apps with this role in focus.
Of course it offers way more but this is some kind of value proposition of the framework that is the reason why it fits my use cases perfectly.
I know itâs been almost 2 weeks, since your post @sacha , but I feel we are at an inflection point.
And if not handled well, Meteor will slowly fade away â likely following Galaxy revenues. Is MDGâs marketing budget the problem? If so, the community needs to step in (there are many ways to do that collaboratively) â combined with stubalio being gone (and he had left the forums a while back to focus on Apollo) I am getting antsy about all of this.
I also feel that people are getting afraid of JS frameworks (hence express is #1 â which is awkward)
Well, my personal solution with Vulcan.js is to develop a new framework on top of Meteor that aims for the same goals at the âoriginalâ Meteor but using a more modern stack. The idea being that everything Meteor-specific is then abstracted away, so you only get the benefits of the technology without being weighed down by Meteorâs current bad image too much.
I can understand if that doesnât work for everybody though, Vulcan is fairly opinionated and might not be suitable for all Meteor developers.
Thanks @sacha
I applaud your effort in the loudest. My concern is that
- itâs hard for a small team to gather enough support in a crowded market, there is a lot of noise now
- this is especially true (as you have noted with different words in comments in state-of-js-2018) that nodejs server frameworks are being challenged
- we donât all use React AND Apollo
In fact, while React has wind in its sail it seems to be slowing (VueJS is an example of competing framework) and I believe the community now realizes that VirtualDOM comes with problems (in this testbench redom is either similar or better â sometimes much better â in many tests: https://rawgit.com/krausest/js-framework-benchmark/master/webdriver-ts-results/table.html [filter by frameworks for an easier read])
Also, I am wondering if GraphQL is as hot as it used to be. In our case, we have custom pubs and man are we more efficient for reactive pubs.
If I look at the atmosphere packages we are using, they are very few (redis-oplog being the prominent one). So maybe the history of Meteor is hurting it, people are not realizing that the framework moved on to work with ES6, NPM packages, and dynamic loads (and almost all major UI frameworks)
You hit the nail on the head there.
I havenât been around Meteor long enough to speak of the transition, I was really in when MDG was announcing that they were dropping support for Blaze (what a marketing fiasco!). Maybe we need to be active contributors? It would be in MDGâs best interest too. How about a MWG (Meteor Working Group)? We meet to discuss this and other issues, bring it up with MDG and have a concerted one-voice to the community. Right now ⌠there is NO voice.