JsBarcode
Barcode generation library written in JavaScript that works in both the bro...
README
Introduction
JsBarcode is a barcode generator written in JavaScript. It supports multiple barcode formats and works in browsers and with Node.js. It has no dependencies when it is used for the web but works with jQuery if you are into that.
Demo
Supported barcodes:
CODE128 (automatic mode switching)
CODE128 A/B/C (force mode)
EAN-13
EAN-8
EAN-5
EAN-2
UPC (A)
UPC (E)
ITF
ITF-14
MSI10
MSI11
MSI1010
MSI1110
Examples for browsers:
First create a canvas (or image)
- ```` html
- <svg id="barcode"></svg>
- <canvas id="barcode"></canvas>
- <img id="barcode"/>
- ````
Simple example:
- ```` js
- JsBarcode("#barcode", "Hi!");
- // or with jQuery
- $("#barcode").JsBarcode("Hi!");
- ````
Result:
Example with options:
- ```` js
- JsBarcode("#barcode", "1234", {
- format: "pharmacode",
- lineColor: "#0aa",
- width:4,
- height:40,
- displayValue: false
- });
- ````
Result:
More advanced use case:
- ```` js
- JsBarcode("#barcode")
- .options({font: "OCR-B"}) // Will affect all barcodes
- .EAN13("1234567890128", {fontSize: 18, textMargin: 0})
- .blank(20) // Create space between the barcodes
- .EAN5("12345", {height: 85, textPosition: "top", fontSize: 16, marginTop: 15})
- .render();
- ````
Result:
Or define the value and options in the HTML element:
Use any `jsbarcode- or data- as attributes where *` is any option.
- ```` html
- <svg class="barcode"
- jsbarcode-format="upc"
- jsbarcode-value="123456789012"
- jsbarcode-textmargin="0"
- jsbarcode-fontoptions="bold">
- </svg>
- ````
And then initialize it with:
- ```` js
- JsBarcode(".barcode").init();
- ````
Result:
Retrieve the barcode values so you can render it any way you'd like
Pass in an object which will be filled with data.
- ``` js
- const data = {};
- JsBarcode(data, 'text', {...options});
- ```
data will be filled with a encodings property which has all the needed values.
See wiki for an example of what data looks like.
Setup for browsers:
Step 1:
Download or get the CDN link to the script:
Name | Supported | Size | CDN |
---|---|---|---|
|------|--------------------|:-----------:|---------------:| | |||
*All* | *All | *10.1 | *[JsBarcode.all.min.js][1]* |
CODE128 | CODE128 | 6.2 | [JsBarcode.code128.min.js][2] |
CODE39 | CODE39 | 5.1 | [JsBarcode.code39.min.js][3] |
EAN | EAN-13, | 6.7 | [JsBarcode.ean-upc.min.js][4] |
ITF | ITF, | 5 | [JsBarcode.itf.min.js][5] |
MSI | MSI, | 5 | [JsBarcode.msi.min.js][6] |
Pharmacode | Pharmacode | 4.7 | [JsBarcode.pharmacode.min.js][7] |
Codabar | Codabar | 4.9 | [JsBarcode.codabar.min.js][8] |
Step 2:
Include the script in your code:
- ```` html
- <script src="JsBarcode.all.min.js"></script>
- ````
Step 3:
You are done! Go generate some barcodes :smile:
Bower and npm:
- ```` sh
- bower install jsbarcode --save
- ````
- ```` sh
- npm install jsbarcode --save
- ````
Node.js:
With canvas:
- ```` javascript
- var JsBarcode = require('jsbarcode');
- // Canvas v1
- var Canvas = require("canvas");
- // Canvas v2
- var { createCanvas } = require("canvas");
- // Canvas v1
- var canvas = new Canvas();
- // Canvas v2
- var canvas = createCanvas();
- JsBarcode(canvas, "Hello");
- // Do what you want with the canvas
- // See https://github.com/Automattic/node-canvas for more information
- ````
With svg:
- ```` javascript
- const { DOMImplementation, XMLSerializer } = require('xmldom');
- const xmlSerializer = new XMLSerializer();
- const document = new DOMImplementation().createDocument('http://www.w3.org/1999/xhtml', 'html', null);
- const svgNode = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
- JsBarcode(svgNode, 'test', {
- xmlDocument: document,
- });
- const svgText = xmlSerializer.serializeToString(svgNode);
- ````
Options:
For information about how to use the options, see the wiki page.
Option | Default | Type |
---|---|---|
|--------|---------------|------| | ||
[`format`](https://github.com/lindell/JsBarcode/wiki/Options#format) | `"auto" | `String` |
[`width`](https://github.com/lindell/JsBarcode/wiki/Options#width) | `2` | `Number` |
[`height`](https://github.com/lindell/JsBarcode/wiki/Options#height) | `100` | `Number` |
[`displayValue`](https://github.com/lindell/JsBarcode/wiki/Options#display-value) | `true` | `Boolean` |
[`text`](https://github.com/lindell/JsBarcode/wiki/Options#text) | `undefined` | `String` |
[`fontOptions`](https://github.com/lindell/JsBarcode/wiki/Options#font-options) | `""` | `String` |
[`font`](https://github.com/lindell/JsBarcode/wiki/Options#font) | `"monospace"` | `String` |
[`textAlign`](https://github.com/lindell/JsBarcode/wiki/Options#text-align) | `"center"` | `String` |
[`textPosition`](https://github.com/lindell/JsBarcode/wiki/Options#text-position) | `"bottom"` | `String` |
[`textMargin`](https://github.com/lindell/JsBarcode/wiki/Options#text-margin) | `2` | `Number` |
[`fontSize`](https://github.com/lindell/JsBarcode/wiki/Options#font-size) | `20` | `Number` |
[`background`](https://github.com/lindell/JsBarcode/wiki/Options#background) | `"#ffffff"` | `String |
[`lineColor`](https://github.com/lindell/JsBarcode/wiki/Options#line-color) | `"#000000"` | `String |
[`margin`](https://github.com/lindell/JsBarcode/wiki/Options#margins) | `10` | `Number` |
[`marginTop`](https://github.com/lindell/JsBarcode/wiki/Options#margins) | `undefined` | `Number` |
[`marginBottom`](https://github.com/lindell/JsBarcode/wiki/Options#margins) | `undefined` | `Number` |
[`marginLeft`](https://github.com/lindell/JsBarcode/wiki/Options#margins) | `undefined` | `Number` |
[`marginRight`](https://github.com/lindell/JsBarcode/wiki/Options#margins) | `undefined` | `Number` |
[`valid`](https://github.com/lindell/JsBarcode/wiki/Options#valid) | `function(valid){}` | `Function` |
Contributions and feedback:
We :heart: contributions and feedback.
If you want to contribute, please check out the CONTRIBUTING.md file.
If you have any question or suggestion create an issue or ask about it in the gitter chat.
Bug reports should always be done with a new issue.
License:
JsBarcode is shared under the MIT license. This means you can modify and use it however you want, even for comercial use. But please give this the Github repo a :star: and write a small comment of how you are using JsBarcode in the gitter chat.
[1]: https://cdn.jsdelivr.net/npm/jsbarcode@3.11.0/dist/JsBarcode.all.min.js "jsdelivr all barcodes"
[2]: https://cdn.jsdelivr.net/npm/jsbarcode@3.11.0/dist/barcodes/JsBarcode.code128.min.js "jsdelivr code128"
[3]: https://cdn.jsdelivr.net/npm/jsbarcode@3.11.0/dist/barcodes/JsBarcode.code39.min.js "jsdelivr code39"
[4]: https://cdn.jsdelivr.net/npm/jsbarcode@3.11.0/dist/barcodes/JsBarcode.ean-upc.min.js "jsdelivr ean/upc"
[5]: https://cdn.jsdelivr.net/npm/jsbarcode@3.11.0/dist/barcodes/JsBarcode.itf.min.js "jsdelivr itf"
[6]: https://cdn.jsdelivr.net/npm/jsbarcode@3.11.0/dist/barcodes/JsBarcode.msi.min.js "jsdelivr msi"
[7]: https://cdn.jsdelivr.net/npm/jsbarcode@3.11.0/dist/barcodes/JsBarcode.pharmacode.min.js "jsdelivr pharmacode"
[8]: https://cdn.jsdelivr.net/npm/jsbarcode@3.11.0/dist/barcodes/JsBarcode.codabar.min.js "jsdelivr codabar"