On libraries, Rust and node_modules depression - JStefanelli.com

submited by
Style Pass
2025-01-06 02:30:07

I am sure that I am not the only one that cringes at the size of every node_modules folder that I come across. Every frontend project somehow "needs" megabytes of dependencies. Even this very website, that avoids all types of frontend frameworks, is still plagued by a 100MB+ node_modules folder mostly to transpile some Typescript. Even the backend of our work website (or web application, I guess), our main product, is filled with tons of PHP dependencies, and out of all of those I only know Laravel And for what I can see online, this is the way for most serious projects. I always presumed that this was because of the high speed of development required in the web app development market, where re-inventing the wheel was simply too slow. However, a series of episodes challenge this notion:

A few weeks back, our web development consultant (whose team set up our main website, since we are a truly tiny startup, which includes a grand total of 2 in-house developers) was working on data gathering for analytics, for which I had to provide some data. Now, this wasn't happening in our mainline repository, this was happening in a small, separated web application that I manage, designed with only the bare minimum of dependencies (3D rendering with Three.js, and Typescript for my sanity). We got in a call to look at what data needed to be sent, but at the end he was struggling to call the API. In this repository there is no "axios" library, so I had to walk through a "senior web developer" how to write a simple fetch() . The other knocks to my beliefs were a bunch of articles, old and new, that popped into my feed. The most relevant of the bunch is this one from all the way back in 2016 about the left-pad fiasco. These two episodes made me start to think about "library abuse" in a more serious manner, compared to simply laughing at "node_modules big" memes. It cannot possibly be the optimal option, long term, to have an entire library for such a simple task as a straight-forward POST call, right? Is having a NPM package for 11 lines of code really necessary?

Leave a Comment