Convert
The smallest & fastest library for really easy, totally type-safe unit conversions in TypeScript & JavaScript.
data:image/s3,"s3://crabby-images/0bde9/0bde99a93fd4e75c325721f2f49cc37c3c0995e6" alt="npm monthly downloads"
npm install convert
yarn add convert
More installation examples below.
convert(5, "miles").to("km");
convertMany("4d 16h").to("minutes");
Features
- Full build time and runtime validation of conversions
- Web frameworks like Next.js and Vite know that Convert is side-effect free, so conversions will be precalculated at build-time, absolutely zero conversion code is sent to clients
- Runs anywhere (browsers, Node, Bun, etc), full ES3 backwards-compatibility
- Tiny bundle size and 0 dependencies
- Supports bigints
Usage
Generated API documentation for the latest version is available online.
View docs.
import convert from "convert";
const { convert } = require("convert");
convert(360, "seconds").to("minutes");
convert(20n, "hours").to("minutes");
convert(5500, "meters").to("best");
convert(5, "kilometers").to("nautical miles");
convert(12, "pounds").to("ounces");
convert(8192, "bytes").to("KiB");
convert(10, "atmospheres").to("kPa");
convert(451, "fahrenheit").to("celsius");
Converting many units
import { convertMany } from "convert";
const { convertMany } = require("convert");
convertMany("1d8h").to("ms");
Converting to best unit
import convert from "convert";
const { convert } = require("convert");
const duration = convert(36, "h").to("best");
"duration is " + duration;
convert(3.5, "km").to("best");
convert(3.5, "km").to("best", "metric");
convert(3.5, "km").to("best", "imperial");
ms
shorthand
import { ms } from "convert";
const { ms } = require("convert");
ms("1d 2h 30min");
ms(86400000);
Installation
Package manager
Convert is published as convert
on npm.
npm install convert
yarn add convert
And then import it in your code like this:
const { convert } = require("convert");
import convert from "convert";
Browsers
Pick your favorite CDN:
ES Modules via CDN
<script type="module">
import convert from "https://cdn.skypack.dev/convert@5";
import convert from "https://esm.run/convert@5";
import convert from "https://cdn.jsdelivr.net/npm/convert@5";
import convert from "https://unpkg.com/convert@5";
</script>
UMD (global)
<script src="https://cdn.jsdelivr.net/npm/convert@5/dist/index.js"></script>
<script src="https://unpkg.com/convert@5/dist/index.js"></script>
Alternatives
Convert is better than other unit conversion libraries because it's faster and smaller than them, while having the same features.
Benchmarks of popular unit conversion libraries, including Convert are available here.
Convert is the fastest, taking less than a microsecond for all functions.
That's a little over 3 million convert()
calls per second.
Bundle size comparison
data:image/s3,"s3://crabby-images/dae37/dae37e31ff0b567cdb83d6532351124ceb8553cd" alt="npm bundle size of convert"
data:image/s3,"s3://crabby-images/d53fc/d53fc6b9d4d02bec84c5e62716bdbc989ce07154" alt="npm bundle size of safe-units"
data:image/s3,"s3://crabby-images/600e2/600e26a09c296f69855aeacc667bcd1076a85d94" alt="npm bundle size of convert-units"
data:image/s3,"s3://crabby-images/19b69/19b6947cfc2a2829d9b3a47de58d7adca5d1a85a" alt="npm bundle size of js-quantities"
data:image/s3,"s3://crabby-images/8acd7/8acd729a0c66971b8f43ac66e7027a136c89457a" alt="npm bundle size of uom-units"