UNPKG

3.24 kBMarkdownView Raw
1<h1 align="center">
2 <br>
3 <img width="365" src="https://cdn.rawgit.com/data-uri/datauri/master/media/datauri.svg" alt="datauri">
4 <br>
5 <br>
6 <br>
7</h1>
8
9Node.js [Module](#module) and [CLI](http://npm.im/datauri-cli) to generate [Data URI scheme](http://en.wikipedia.org/wiki/Data_URI_scheme).
10
11> The data URI scheme is a uniform resource identifier (URI) scheme that provides a way to include data in-line in web pages as if they were external resources.
12
13from: [Wikipedia](http://en.wikipedia.org/wiki/Data_URI_scheme)
14
15## MODULE [![Build Status](https://github.com/data-uri/datauri/actions/workflows/main.yml/badge.svg?branch=main)](https://github.com/data-uri/datauri/actions/workflows/main.yml?query=branch%3Amain)
16
17`npm install datauri`
18
19### Getting started
20
21By default, datauri module returns a promise, which is resolved with `data:uri` string or rejected with read file error:
22
23```js
24const datauri = require('datauri');
25
26const content = await datauri('test/myfile.png');
27
28console.log(content);
29//=> "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA..."
30```
31
32### Callback style and meta data
33
34```js
35const datauri = require('datauri');
36
37datauri('test/myfile.png', (err, content, meta) => {
38 if (err) {
39 throw err;
40 }
41
42 console.log(content); //=> "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA..."
43
44 console.log(meta.mimetype); //=> "image/png"
45 console.log(meta.base64); //=> "iVBORw0KGgoAAAANSUhEUgAA..."
46 console.log(meta.buffer); //=> file buffer
47});
48```
49
50### CSS parser
51
52```js
53const datauriCSS = require('datauri/css');
54
55await datauriCSS('test/myfile.png');
56//=> "\n.case {\n background-image: url('data:image/png; base64,iVBORw..."
57
58await datauriCSS('test/myfile.png', {
59 className: 'myClass',
60 width: true,
61 height: true
62});
63//=> adds image width and height and custom class name
64```
65
66### Synchronous calls
67
68```js
69const Datauri = require('datauri/sync');
70const meta = Datauri('test/myfile.png');
71
72console.log(meta.content); //=> "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA..."
73console.log(meta.mimetype); //=> "image/png"
74console.log(meta.base64); //=> "iVBORw0KGgoAAAANSUhEUgAA..."
75console.log(meta.buffer); //=> file buffer
76```
77
78### From a Buffer
79
80If you already have a file Buffer, that's the way to go:
81
82```js
83const DatauriParser = require('datauri/parser');
84const parser = new DatauriParser();
85
86const buffer = fs.readFileSync('./hello');
87
88parser.format('.png', buffer); //=> "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA..."
89```
90
91### From a string
92
93```js
94const DatauriParser = require('datauri/parser');
95const parser = new DatauriParser();
96
97parser.format('.png', 'xkcd'); //=> "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA..."
98```
99
100## Contribute
101
102```CLI
103$ npm install
104```
105
106To run test specs
107
108```CLI
109$ npm test
110```
111
112## [ChangeLog](https://github.com/data-uri/datauri/releases)
113
114## Requirements
115
116Node.js 10+
117
118### Previous Node versions and deprecated features:
119
120Node.js 8
121`npm install --save datauri@3`
122docs: https://github.com/data-uri/datauri/blob/v3.0.0/docs/datauri.md
123
124Node.js 4+
125`npm install --save datauri@2`
126docs: https://github.com/data-uri/datauri/blob/v2.0.0/docs/datauri.md
127
128## License
129
130MIT License
131
132(c) [Data-URI.js](https://github.com/data-uri)
133
134(c) [Helder Santana](https://heldr.com)