Package Exports
- datauri
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (datauri) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
datauri

A simple Data URI scheme generator built on top of Node.js. To install datauri, just run:
npm install -g datauri
(it may require Root privileges)
CLIENT
Print datauri scheme
To print a datauri scheme from a file
$ datauri brand.png
CSS Background
You can generate or update an output css file with datauri background:
$ datauri brand.png asset/background.css
If you want to define a Class Name, just type:
$ datauri brand.png asset/background.css MyNewClass
API
Function
var Datauri = require('datauri'),
dUri = Datauri('test/myfile.png');
console.log(dUri); //=> "..."
Class
var Datauri = require('datauri'),
dUri = new Datauri('test/myfile.png');
console.log(dUri.content); //=> "..."
console.log(dUri.mimetype); //=> "image/png"
console.log(dUri.base64); //=> "iVBORw0KGgoAAAANSUhEUgAA..."
console.log(dUri.getCSS()); //=> "\n.case {\n background: url('..."
console.log(dUri.getCSS("myClass")); //=> "\n.myClass {\n background: url('..."
Async
var Datauri = require('datauri'),
dUri = new Datauri();
dUri.on('encoded', function (content) {
console.log(content); //=> "...";
});
dUri.on('error', function (content) {
console.log('Fail!');
});
dUri.encode('test/myfile.png');
Chaining all stuff
dUri.on('encoded', function (content, datauri) {
console.log(content); //=> "..."
console.log(datauri.mimetype); //=> "image/png"
console.log(datauri.base64); //=> "iVBORw0KGgoAAAANSUhEUgAA..."
console.log(datauri.getCSS()); //=> "\n.case {\n background: url('..."
console.log(datauri.getCSS("myClass")); //=> "\n.myClass {\n background: url('..."
})
.on('error', function (content) {
console.log('Fail!');
})
.encode('test/myfile.png');
Function callback
var DataURI = require('datauri');
DataURI('test/myfile.png', function (err, content, datauri) {
if (err) {
throw err;
}
console.log(content); //=> "..."
console.log(datauri.mimetype); //=> "image/png"
console.log(datauri.base64); //=> "iVBORw0KGgoAAAANSUhEUgAA..."
console.log(datauri.getCSS()); //=> "\n.case {\n background: url('..."
console.log(datauri.getCSS("myClass")); //=> "\n.myClass {\n background: url('..."
});
Promises /A+ standard
var DataURI = require('datauri').promises;
DataURI('test/myfile.png').then(function (content) {
console.log(content); //=> "..."
},
function (err) {
throw err;
});
Create from a string
var Datauri = require('datauri'),
dUri = new Datauri();
dUri.format('.png', 'xkcd');
console.log(dUri.content); //=> ""
console.log(dUri.mimetype); //=> "image/png"
console.log(dUri.base64); //=> "eGtjZA=="
console.log(dUri.getCSS("myClassName")); //=> "\n.myClassName {\n background: url('..."
GRUNT
There are a bunch of grunt plugins running on top of datauri module.
- grunt-datauri - Create base64 encoded data-uris for css from images
- grunt-imweb - IMWEB Tasks Collection For Daily Workflow.
- grunt-static-inline - A grunt plugin to replace url from static files such as img,js,css an put inline in a template.
- grunt-data-uri - Convert to data-uri from image path.
- grunt-inline
DEVELOPING
The only essential library to develop datauri is jshint.
$ make install
$ make test
If you'd like to test the full process including npm installer, just run:
$ make fulltest
Release notes
- 0.5 - Format data uri from a string
- 0.4 - Promises support
- 0.3 - API Rewritten from the top to the bottom + full async compatibility
- 0.2 - Splitted in submodules mimer and templayed
- 0.1 - First release
License
MIT License (c) Helder Santana