Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

mime

broofa202.3mMIT4.0.6TypeScript support: included

A comprehensive library for mime-type mapping

extension, file, mime, mime-db, mimetypes, util

readme

Mime

NPM downloads Mime CI

An API for MIME type information.

  • All mime-db types
  • Compact and dependency-free mime's badge
  • Full TS support

[!Note] mime@4 is now latest. If you're upgrading from mime@3, note the following:

  • mime@4 is API-compatible with mime@3, with one two exceptions:
    • Direct imports of mime properties no longer supported
    • mime.define() cannot be called on the default mime object
  • ESM module support is required. ESM Module FAQ.
  • Requires an ES2020 or newer runtime
  • Built-in Typescript types (@types/mime no longer needed)

Installation

npm install mime

Quick Start

For the full version (800+ MIME types, 1,000+ extensions):

import mime from 'mime';

mime.getType('txt');                    // ⇨ 'text/plain'
mime.getExtension('text/plain');        // ⇨ 'txt'

Lite Version mime/lite's badge

mime/lite is a drop-in mime replacement, stripped of unofficial ("prs.*", "x-*", "vnd.*") types:

import mime from 'mime/lite';

API

mime.getType(pathOrExtension)

Get mime type for the given file path or extension. E.g.

mime.getType('js');             // ⇨ 'text/javascript'
mime.getType('json');           // ⇨ 'application/json'

mime.getType('txt');            // ⇨ 'text/plain'
mime.getType('dir/text.txt');   // ⇨ 'text/plain'
mime.getType('dir\\text.txt');  // ⇨ 'text/plain'
mime.getType('.text.txt');      // ⇨ 'text/plain'
mime.getType('.txt');           // ⇨ 'text/plain'

null is returned in cases where an extension is not detected or recognized

mime.getType('foo/txt');        // ⇨ null
mime.getType('bogus_type');     // ⇨ null

mime.getExtension(type)

Get file extension for the given mime type. Charset options (often included in Content-Type headers) are ignored.

mime.getExtension('text/plain');               // ⇨ 'txt'
mime.getExtension('application/json');         // ⇨ 'json'
mime.getExtension('text/html; charset=utf8');  // ⇨ 'html'

mime.getAllExtensions(type)

[!Note] New in mime@4

Get all file extensions for the given mime type.

`javascript --run default mime.getAllExtensions('image/jpeg'); // ⇨ Set(3) { 'jpeg', 'jpg', 'jpe' }


## Custom `Mime` instances

The default `mime` objects are immutable.  Custom, mutable versions can be created as follows...
### new Mime(type map [, type map, ...])

Create a new, custom mime instance.  For example, to create a mutable version of the default `mime` instance:

```javascript
import { Mime } from 'mime/lite';

import standardTypes from 'mime/types/standard.js';
import otherTypes from 'mime/types/other.js';

const mime = new Mime(standardTypes, otherTypes);

Each argument is passed to the define() method, below. For example new Mime(standardTypes, otherTypes) is synonomous with new Mime().define(standardTypes).define(otherTypes)

mime.define(type map [, force = false])

[!Note] Only available on custom Mime instances

Define MIME type -> extensions.

Attempting to map a type to an already-defined extension will throw unless the force argument is set to true.

mime.define({'text/x-abc': ['abc', 'abcd']});

mime.getType('abcd');            // ⇨ 'text/x-abc'
mime.getExtension('text/x-abc')  // ⇨ 'abc'

Command Line

Extension -> type

$ mime scripts/jquery.js
text/javascript

Type -> extension

$ mime -r image/jpeg
jpeg

changelog

Changelog

4.0.6 (2024-12-17)

Bug Fixes

4.0.5 (2024-12-17)

Bug Fixes

4.0.4 (2024-07-06)

4.0.3 (2024-04-25)

Bug Fixes

  • add types dir to package.json#files, fixes #310 (a547ca7)

4.0.2 (2024-04-24)

Bug Fixes

4.0.1 (2023-12-17)

Bug Fixes

4.0.0 (2023-11-29)

4.0.0-beta.1 (2023-09-14)

4.0.0-beta.0 (2023-09-13)

⚠ BREAKING CHANGES

  • drop node < 18 from CI matrix
  • exit from CLI with non-zero exit code when no result
  • drop CJS support, switch to TS

Features

  • add getAllExtensions() method (f22b6f0)
  • add reverse lookup option (--reverse, -r) feature to CLI (e0da103)

ci

  • drop node < 18 from CI matrix (ef38fd5)

3.0.0 (2021-11-03)

⚠ BREAKING CHANGES

  • drop support for node < 10.x

Bug Fixes

  • skypack.dev for direct browser import, fixes #263 (41db4c0)

update

  • drop support for node < 10.x (8857363)

2.6.0 (2021-11-02)

Features

2.5.2 (2021-02-17)

Bug Fixes

2.5.0 (2021-01-16)

Features

2.4.7 (2020-12-16)

Bug Fixes

  • update to latest mime-db (43b09ef)

2.4.6 (2020-05-27)

Bug Fixes

2.4.5 (2020-05-01)

Bug Fixes

2.4.4 (2019-06-07)

2.4.3 (2019-05-15)

2.4.2 (2019-04-07)

Bug Fixes

  • don't use arrow function introduced in 2.4.1 (2e00b5c)

2.4.1 (2019-04-03)

Bug Fixes

  • update MDN and mime-db types (3e567a9)

2.4.0 (2018-11-26)

Features

2.3.1 (2018-04-11)

Bug Fixes

2.3.0 (2018-04-11)

Bug Fixes

Features

2.2.2 (2018-03-30)

Bug Fixes

2.2.1 (2018-03-30)

Bug Fixes

  • Retain type->extension mappings for non-default types. Fixes #180 (b5c83fb)

2.2.0 (2018-01-04)

Features

  • Retain type->extension mappings for non-default types. Fixes #180 (10f82ac)

2.1.0 (2017-12-22)

Features

2.0.5 (2017-12-22)

Bug Fixes

  • ES5 support (back to node v0.4) (f14ccb6)

Changelog

v2.0.4 (24/11/2017)

  • [closed] Switch to mime-score module for resolving extension contention issues. #182
  • [closed] Update mime-db to 1.31.0 in v1.x branch #181

v1.5.0 (22/11/2017)

  • [closed] need ES5 version ready in npm package #179
  • [closed] mime-db no trace of iWork - pages / numbers / etc. #178
  • [closed] How it works in brownser ? #176
  • [closed] Missing ./Mime #175
  • [closed] Vulnerable Regular Expression #167

v2.0.3 (25/09/2017)

No changelog for this release.


v1.4.1 (25/09/2017)

  • [closed] Issue when bundling with webpack #172

v2.0.2 (15/09/2017)

  • [V2] fs.readFileSync is not a function #165
  • [closed] The extension for video/quicktime should map to .mov, not .qt #164
  • [V2] [v2 Feedback request] Mime class API #163
  • [V2] [v2 Feedback request] Resolving conflicts over extensions #162
  • [V2] Allow callers to load module with official, full, or no defined types. #161
  • [V2] Use "facets" to resolve extension conflicts #160
  • [V2] Remove fs and path dependencies #152
  • [V2] Default content-type should not be application/octet-stream #139
  • [V2] reset mime-types #124
  • [V2] Extensionless paths should return null or false #113

v2.0.1 (14/09/2017)

  • [closed] Changelog for v2.0 does not mention breaking changes #171
  • [closed] MIME breaking with 'class' declaration as it is without 'use strict mode' #170

v2.0.0 (12/09/2017)

  • [closed] woff and woff2 #168

v1.4.0 (28/08/2017)

  • [closed] support for ac3 voc files #159
  • [closed] Help understanding change from application/xml to text/xml #158
  • [closed] no longer able to override mimetype #157
  • [closed] application/vnd.adobe.photoshop #147
  • [closed] Directories should appear as something other than application/octet-stream #135
  • [closed] requested features #131
  • [closed] Make types.json loading optional? #129
  • [closed] Cannot find module './types.json' #120
  • [V2] .wav files show up as "audio/x-wav" instead of "audio/x-wave" #118
  • [closed] Don't be a pain in the ass for node community #108
  • [closed] don't make default_type global #78
  • [closed] mime.extension() fails if the content-type is parameterized #74

v1.3.6 (11/05/2017)

  • [closed] .md should be text/markdown as of March 2016 #154
  • [closed] Error while installing mime #153
  • [closed] application/manifest+json #149
  • [closed] Dynamic adaptive streaming over HTTP (DASH) file extension typo #141
  • [closed] charsets image/png undefined #140
  • [closed] Mime-db dependency out of date #130
  • [closed] how to support plist? #126
  • [closed] how does .types file format look like? #123
  • [closed] Feature: support for expanding MIME patterns #121
  • [closed] DEBUG_MIME doesn't work #117

v1.3.4 (06/02/2015)

No changelog for this release.


v1.3.3 (06/02/2015)

No changelog for this release.


v1.3.1 (05/02/2015)

  • [closed] Consider adding support for Handlebars .hbs file ending #111
  • [closed] Consider adding support for hjson. #110
  • [closed] Add mime type for Opus audio files #94
  • [closed] Consider making the Requesting New Types information more visible #77

v1.3.0 (05/02/2015)

  • [closed] Add common name? #114
  • [closed] application/x-yaml #104
  • [closed] Add mime type for WOFF file format 2.0 #102
  • [closed] application/x-msi for .msi #99
  • [closed] Add mimetype for gettext translation files #98
  • [closed] collaborators #88
  • [closed] getting errot in installation of mime module...any1 can help? #87
  • [closed] should application/json's charset be utf8? #86
  • [closed] Add "license" and "licenses" to package.json #81
  • [closed] lookup with extension-less file on Windows returns wrong type #68

v1.2.11 (15/08/2013)

  • [closed] Update mime.types #65
  • [closed] Publish a new version #63
  • [closed] README should state upfront that "application/octet-stream" is default for unknown extension #55
  • [closed] Suggested improvement to the charset API #52

v1.2.10 (25/07/2013)

  • [closed] Mime type for woff files should be application/font-woff and not application/x-font-woff #62
  • [closed] node.types in conflict with mime.types #51

v1.2.9 (17/01/2013)

  • [closed] Please update "mime" NPM #49
  • [closed] Please add semicolon #46
  • [closed] parse full mime types #43

v1.2.8 (10/01/2013)

  • [closed] /js directory mime is application/javascript. Is it correct? #47
  • [closed] Add mime types for lua code. #45

v1.2.7 (19/10/2012)

  • [closed] cannot install 1.2.7 via npm #41
  • [closed] Transfer ownership to @broofa #36
  • [closed] it's wrong to set charset to UTF-8 for text #30
  • [closed] Allow multiple instances of MIME types container #27