Yarn (package manager) explained

Yarn
Developer:Various
Released:[1]
Programming Language:TypeScript, JavaScript
Platform:Cross-platform
Genre:Package manager
License:BSD 2-Clause License

Yarn is one of the main JavaScript package managers,[2] [3] developed in 2016 by Sebastian McKenzie of Meta (formerly Facebook) for the Node.js JavaScript runtime environment. An alternative to the npm package manager, Yarn was created as a collaboration of Facebook (now Meta), Exponent (now Expo.dev), Google, and Tilde (the company behind Ember.js) to solve consistency, security, and performance problems with large codebases.[4]

History

Yarn 1.0 was able to forcibly override the version of transitive dependencies.[5] [6]

Plugins

Users can write their own plugins for Yarn.

Constraints

Yarn constraints allow users to enforce rules for their dependencies or manifest fields across scoped workspaces.

Offline cache

Downloaded packages are cached and stored as a single file.

Plug'n'Play

Plug'n'Play allows users to run Node projects without node_modules folder, defining the way or location to resolve dependencies package files with the Plug-n-Play-control file. This feature is aimed to fix an unwell structured node_modules architecture and resulting in a faster Node.js application start-up time.

Plugins

Plugins can add new resolvers, fetchers, linkers, commands, and can also register to some events or be integrated with each other, most features of Yarn are implemented through plugins, including yarn add and yarn install, which are also preinstalled plugins.

Protocols

Users can define which protocol will be used to resolve certain packages, for example, the git protocol is used for downloading a public package from a Git repository, and the patch protocol is used for creating a patched copy of the original package.

Release Workflow

Release Workflow automatically upgrades relative packages among monorepos workspaces when root packages are upgraded.

Workspaces

Workspaces allow multiple projects to work together in the same repository and automatically apply changes to other relatives when source code is modified, allowing installation of multiple packages in a single pass by running the installation command only once.

Zero-Installs

Zero-Installs solve the needs of installation of packages when packages is required to install when the codes is just fresh fetched to local.

Comparison to npm

Syntax

To install yarn: npm install -g yarn

To install a package with yarn:[9] yarn add package-name

To install a package with yarn for development and testing purposes: yarn add package-name --dev

NB: in the first versions, it was: yarn install package-name --save-dev

See also

Notes and References

  1. Web site: Earliest releases of yarn . GitHub . Jun 18, 2016.
  2. Web site: 2022-09-28. Package management basics. MDN.
  3. Web site: 2022-02-05. 5 best JavaScript Package Managers. Dunebook.com.
  4. Web site: 2016-10-11. Yarn: A new package manager for JavaScript. 2021-11-22. Engineering at Meta. en-US.
  5. Web site: Christoph Nakazawa, Maël Nison . Announcing Yarn 1.0 . 5 October 2024 . 7 September 2017.
  6. Web site: Nayyar . Vivek . How to fix Security Vulnerabilities in NPM Dependencies in 3 Minutes . 5 October 2024 . 21 March 2020.
  7. Web site: 2021-09-21. Package Manager – NPM and Yarn Explained with Examples. Sitepoint.
  8. Web site: 2021-08-10. How To Install and Use the Yarn Package Manager for Node.js. DigitalOcean.
  9. Web site: 2023-02-04. Yarn vs npm: Everything You Need to Know. CodeSweetly.