Are we ready for javascript without a build step on the front end in 2023?
On the current typescript / anti-typescript internet drama I saw someone mention javascript without a build step.
Do you think we're already there?
Last time I attempted it:
- there were too many libraries I couldn't import
- JSX (using babel) had a warning saying you shouldn't do it in the browser for production
- there was some advice against not using a bundler, because several requests for different .js files is slower and bigger than a bundled package
You are viewing a single comment
And the simple answer is no. You can remove a layer here and there, but this is what the modern dev environment looks like.
I mean sure you can implement all that yourself and carry all the extra cognitive load, but it is not productive to even skip babel or so. There is no point, but the challenge.
Of course it is a bit more complicated to pick the right tools and you don't have to use everything, but that's a whole different discussion.
I would disagree.
There's more to software than big corporate websites or massive FOSS projects. I've made tons of little one-html-file sites, like an inflation-adjusted income calculator, a scheduling app I've used every week for 4 years, a chemistry converter/calculator for a class I was in, even my resume site is just a single html file. Not only that but most of my published deno modules are nothing more than a main.js, a readme, and a gitignore (no package.json, no node_modules, no install step).
You don't need tests, and a linter, and babel, and tree shaking, and JSX, and typescript, and souce maps just to make a resume site, or an infographic, or a one-off internal dashboard, or a simple blog, or a restraunt menu. Modern ES http imports and modern JS tooling is enough.
None of the tools are really made for the most trivial use cases though. Although it doesn't take much effort to set everything up in a simple project I would probably also skip most of it. But this discussion about tiny one off projects is kinda pointless as you don't have many of the problems to solve anyway.
I implemented a reddit frontend (kiosk mode) a while back using only vanilla JS for fun, because a previous implementation by someone else broke. There was not really a point though as it wasn't even simpler than using the proper tools. It was just for the hell of it, but nowhere close to a "real" project.