So, 12 years have passed after the infamous "Dash Memo" leak was published.
For those who doesn't know: V8 team did a side gig and created a new language with its own VM as they were exhausted maintaining all the JS shortcomings. So as a side project someone forked V8 and created what is now known as Dart . At those times it was called Dash. Some more effort was put into this and they managed to make a BETTER language for the Web.
As Google controls the Chrome development it was obvious they have power to do a tectonic shift: add another default language for the web and in a long time remove all that JS legacy. Or leave it as is.
But, someone at the team saw the email and leaked it to the public.
The first passage stated:
And their proposal:
Did they want to harm web developers? No. Did they want to make web development better? Yes!
They actually wanted to add optional types, make language tooling friendly, and more performant...all of this was later promised by TypeScript. That everyone wants to improve because the compilation time is slow. When we added TS to our project in 2016 the compilation time jumped from 40 seconds to...8 minutes. No shit. 4 years have passed I still see articles on how someone rewrote TS Compiler in Rust or Go and got 4000x improvement compilation time. Remember that TypeScript Compiler just converts one text into the other...
What Dash wanted to give us
Remember it was 2012, Microsoft just issued TypeScript 0.8 which was not needed by anyone in the web at that time. React was not a thing.
But the web community started a hysteria saying that Google wanted to 'lock' them into some Google owned language. Read this absurd again. So they did not want to get a default new better language and instead welcomed TypeScript that is 100% controlled by Microsoft that was known for making very bad things to devs with their dominance of IE and Windows. Then they welcomed React that is 100% controlled by Facebook. They are all vendor lock technologies. They are done in public but that does not mean you have any control of them. Even W3C is a useless org without Google and Apple. Yet nobody cries over HTML being vendor locked...
What would happen instead?
Let's imagine they added Dash/Dart to the Chrome in 2015. Dart compiles to JS without any issues. So the backward compatibility would be saved even if Apple rejected to add DartVM to Safari. Firefox was not a thing anymore so we don't care about Mozilla at all. You could serve two bundles (LIKE ACTUALLY LOTS OF WEB APPS DO TODAY) : one bundle for DartVM. The other for JS VM for Safari.
Live reload. Don't compare to web hot reload. In Flutter you can save the file and see updated app without refresh or state change. We still don't have it in current web dev.
Finally normal UI toolkit made on tech made for...UI! Not for text documents targeting to some basement in Zurich in 1988...
Same language for logic and UI
The same language for logic and for the UI markup. No more: Learn JS, Learn HTML, Learn CSS. Just: learn Dart. Don't switch between completely different mind stacks. Flutter Widget code is 100% Dart code.
Absolutely the same project now runs on : Web, macOS, Windows, Linux, iOS, Android. No more Electrons, DENOs, Ionics, god knows what else.
Yes, we would get a 'free' Flutter UI toolkit just out of the box, for free! I am more than sure the next step for Google would be to replace the HTML/CSS garbage (they still have like 15 CSS technologies to center things) with Skia + Flutter. With natural integration into DartVM. No more huge 5Mb bundles to load the bundle and fonts...the platform provides it for you.
Real apps, not document markup hacks
With all of the above we would finally get a normally functioning apps that can be downloaded via the browser. No more strange text input, scrolling, CSS issues between browsers...Just a regular desktop/mobile app as we all used to them, just running under the web address. With 60 FPS!
The history went as it went. We can't change it.
Dart survived, found a new free land called Flutter and blossoms from year to year.