Back when yarn was first released, the defining feature was yarn's lockfile, which sped up dependency tree resolution and thus the overall install of a project. Well, npm 5 came out with a lockfile a few months later. I don't know if it's anything new, but I've noticed in the last several months that both large community projects, enterprise blog articles, and individual stuff on platforms like dev.to always put the yarn commands first with npm commands as a secondary line, or a comment underneath the yarn command.
Why? Why do people still use yarn? Why does it seem like yarn is preferred these days? What differentiators does it actually have against npm 6.x?
 

 
    
Oldest comments (19)
I now prefer NPM, but NPM does sometimes have problem with installing from package-lock.json.
Some other still missing features of NPM include,
Luckily, I now know an easy way to
npm-not-yarnandyarn-not-npm, with zero dependency.It is a best idea to pin dependencies and engines visibly for open source contributors, anyway.
From my own personal experience, I'm going to start using
yarn.I started using
yarndue to ReactNative and was blown away by the install speeds. It was easily 2-3 times faster thannpm. I haven't tested it for other than React or ReactNative but I think I'll definitely be using it a lot more in the near future.Hi Neerja. I can tell
yarnis faster. Recently I usednpmfor a fresh React Native project and... slower.Yarn is still faster that's all I can say.
"NPM is by far the most popular so why switch to yarn" is what 90% people would say in my opinion
That's kind of why I posed this question. I used yarn initially for the lockfile and moved back to npm when it added a lockfile. Want to understand why people still use yarn.
try
yarn add express
and
npm i express
You can see the difference by yourself. Yes, I love it because it's faster but also it's easier to run scripts with yarn. You don't have to
npm run dev
just
yarn dev
I'm lazy; I hate to type another 3 letter wordπ
But having different lockfiles can put you in a lot of dependency issues.
So if I clone a project I'll look for the lockfile. And will use yarn and npm depending upon it.
So the thing is, yarn can install stuff faster.
Maybe time for me to go back to yarn, then!
I'm really liking
yarn pnp. The idea that you don't have to donpm installor think at all aboutnode_modulesis awesome. Another great thing is that all your dependencies, as well as yarn itself, are stored inside your repo. I like the direction that yarn takes you into. It takes you away from reliance on npm, and allows you to be self-sufficient.pnpis new to me... will have to see how it works. It looks like its resolution gets funky with typescript.I've been using TypeScript without much problem. If you're referring to TS in VSCode, you can use a custom workspace TS version (and pnpfy it) for the imports to get resolved properly.
Yarnis fasterIt's a My dad is stronger than your dad discussion.
I pick Yarn, because it installs dependencies faster and I can use the
yarncommand-line tool to execute both dependencies and npm scripts. I frequently mess upnpm/npx/npm runThat's a good comparisonπ
I recently bricked the npm setup on my windows machine, immediately installed yarn and just continued coding. Being versatile enough to use both is fantastic!
I have found yarn to generally be faster in personal projects but haven't done the proper benchmarking to confirm!
I am going to add something, I prefer cdns because esmodules but I also prefer pika cdn