qr.js
JavaScript library for generating QR codes
qr.js is a pure JavaScript library for generating QR codes utilising HTML5 technology.
Originally based on jsqrencode but with cleaner safer code and not to mention a new simple and understandable API.
This library requires HTML5 to work as its <canvas> element is used to render the QR code.
Install
Install using the package manager for your desired environment(s):
# for node.js:
$ npm install qr-js
# OR; for the browser:
$ bower install qr-jsExamples
In the browser:
<html>
<body>
<canvas id="qr-code"></canvas>
<script src="/path/to/qr.min.js"></script>
<script>
qr.canvas({
canvas: document.getElementById('qr-code'),
value: 'http://neocotic.com/qr.js'
});
</script>
</body>
</html>In node.js:
var qr = require('qr-js');
qr.saveSync('http://neocotic.com/qr.js', 'qrcode.png');API
Standard Data
The following configuration data options are recognised by all of the core API methods (all of which are optional):
| Property | Description | Default |
|---|---|---|
| background | Background colour to be used | White (i.e. #fff) |
| canvas |
<canvas> element in which the QR
code should be rendered
|
Creates a new element |
| foreground | Foreground colour to be used | Black (i.e. #000) |
| level |
ECC level to be
applied (e.g. L, M, Q, H)
|
Low (i.e. L) |
| size |
Module size of the generated QR
code (e.g. 1-10 — actual size of the QR
code symbol and is scaled to 25 pixels)
|
4 |
| value | Value to be encoded in the generated QR code | Empty string (i.e. "") |
What is ECC?
ECC (Error Correction Capacity) levels represent the amount of data that can be restored if the QR
code symbol is smudged or damanged. There are four ECC
levels ranging from L (smallest) to H (best);
- L
- Low — Approx. 7% of codewords can be restored
- M
- Medium — Approx. 15% of codewords can be restored
- Q
- Quartile — Approx. 25% of codewords can be restored
- H
- High — Approx. 30% of codewords can be restored
canvas([data|value])
Renders a QR code in an HTML5
<canvas> element for a given value.
// Render the QR code on a newly created canvas element
var canvas = qr.canvas('http://neocotic.com/qr.js');
document.body.appendChild(canvas);
// Re-render the QR code on an existing element
qr.canvas({
canvas: canvas,
value: 'https://github.com/neocotic/qr.js'
});image([data|value])
Renders a QR code in an HTML
<img> element for a given value.
// Render the QR code on a newly created img element
var img = qr.image('http://neocotic.com/qr.js');
document.body.appendChild(img);
// Re-render the QR code on an existing element
qr.image({
image: img,
value: 'https://github.com/neocotic/qr.js'
});image(1) also accepts
these additional data options
| Property | Description | Default |
|---|---|---|
| image |
<img> element in which the QR
code should be rendered
|
Creates a new element |
| mime | MIME type to process the QR code image |
PNG (i.e.
image/png)
|
save([data|value][, path], callback)
Saves a QR code, which has been rendered for a given value, to the user's file system.
// Render a QR code to a PNG file
qr.save('http://neocotic.com/qr.js', 'qr.png', function(err) {
if (err) throw err;
// ...
});
// Render a QR code to a JPEG file
qr.save({
mime: 'image/jpeg',
path: 'qr.jpg',
value: 'https://github.com/neocotic/qr.js'
}, function(err) {
if (err) throw err;
// ...
});save(3) also accepts
these additional data options
| Property | Description | Default |
|---|---|---|
| mime | MIME type to process the QR code image |
PNG (i.e.
image/png)
|
| path¹ | Path to which the QR code should be saved | Required if not specified as an argument |
| ¹ Ignored in browsers | ||
saveSync([data|value][, path])
Synchronous save(3).
toDataURL([data|value])
Returns a data URL for
rendered QR code. This is a convenient
shorthand for dealing with the native HTMLCanvasElement.prototype.toDataURL
function.
console.log(qr.toDataURL('http://neocotic.com/qr.js')); // "..."
console.log(qr.toDataURL({
mime: 'image/jpeg',
value: 'https://github.com/neocotic/qr.js'
})); // "..."toDataURL(1) also
accepts these additional data options
| Property | Description | Default |
|---|---|---|
| mime | MIME type to process the QR code image |
PNG (i.e.
image/png)
|
Miscellaneous
noConflict()
Returns qr in a no-conflict state, reallocating the qr global variable
name to its previous owner, where possible.
This is really just intended for use within a browser.
<script src="/path/to/conflict-lib.js"></script>
<script src="/path/to/qr.min.js"></script>
<script>
var qrNC = qr.noConflict();
// Conflicting lib works again and use qrNC for this library onwards...
</script>VERSION
The current version of qr.
console.log(qr.VERSION); // "1.1.4"Canvas Support
For browser users; their browser must support the HTML5 canvas element or the API will throw an error immediately.
For node.js users; qr.js heavily depends on node-canvas to support the HTML5 canvas element in the node.js environment. Unfortunately, this library is dependant on Cairo, which is not managed by npm. Before you are able to install qr.js (and it's dependencies), you must have Cairo installed. Please see the node-canvas wiki for steps on how to do this on various platforms.
Changes
Version 1.1.4
- #2 Fix padding issues
- #35 Make the QR-code center-aligned
- #38 Update node-canvas dependency version to support Node.js v4 and above
Bugs
If you have any problems with this library or would like to see the changes currently in development browse our issues.
Questions?
Take a look at the documentation to get a better understanding of what the code is doing.
If that doesn't help, feel free to follow me on Twitter, @neocotic.