在不少项目里面,对条形码和二维码的生成和打印也是一种很常见的操做,在Web项目里面,咱们能够利用JS生成条形码和二维码的组件有不少。本文引入两个比较普遍使用的JS组件,用来处理条形码和二维码的生成处理,并介绍如何利用CLODOP组件实现内容的打印输出。
生成条形码使用组件JsBarcode,生成二维码使用组件qrcodejs。javascript
条码的做用通常在一些商品标签上,方便使用条码枪快速、准确录入信息。
以下所示是一种条形码css
这里条形码生成使用了JsBarcode组件进行处理,它支持不少格式的条码格式,以下所示。html
它的简单代码例子以下所示。java
//HTML代码 <svg id="barcode"></svg> <!-- or --> <canvas id="canvas"></canvas> <!-- or --> <img id="barcode"/> //JS代码 JsBarcode("#barcode", "Hi!"); // or with jQuery $("#barcode").JsBarcode("Hi!");
生成的图片格式以下所示。jquery
JsBarcode组件支持多种选项参数的设置,以下所示的代码canvas
JsBarcode("#barcode", "1234", { format: "pharmacode", lineColor: "#0aa", width:4, height:40, displayValue: false }); 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();
经过该组件的案例代码介绍,咱们能够了解到生成常规二维码的使用方式。
例如咱们在界面上添加了如下HTML代码。框架
<div class="row" id="barDiv1"> <div class="col-md-4 col-sm-4 col-xs-4"> 条形码(770 145 896 701):<br /> <img alt="" id="barcode1" /> </div> <div class="col-md-4 col-sm-4 col-xs-4"> 条形码(770 145 896 702):<br /> <img alt="" id="barcode2" /> </div> <div class="col-md-4 col-sm-4 col-xs-4"> 条形码(770 145 896 703):<br /> <img alt="" id="barcode3" /> </div> </div>
而后经过JS代码实现二维码的生成。svg
//使用JsBarcode生成条形码 for (var i = 1; i < 10; i++) { var barcodeValue = "77014589670" + i;//前缀 + 数值 JsBarcode("#barcode" + i, barcodeValue, { format: "CODE128", displayValue: true, fontSize: 24, lineColor: "#0cc" }); }
最后咱们能够看到具体的生成效果以下所示。函数
从这里咱们能够看到,使用JS实现条形码的生成是很是方便简洁的,同事速度也是很不错的。测试
二维码实现能够经过使用组件qrcodejs进行生成,二维码也可使用组件jquery-qrcode进行生成,也相对比较简洁,不过打印二维码文档的时候,jquery-qrcode没有显示二维码图片,而组件qrcodejs则工做正常,所以推荐使用组件qrcodejs。
这个qrcodejs组件使用方式也很简单,基础使用代码以下所示。
<div id="qrcode"></div> <script type="text/javascript"> new QRCode(document.getElementById("qrcode"), "http://jindo.dev.naver.com/collie"); </script>
复杂一点的使用JS代码以下所示。
<div id="qrcode"></div> <script type="text/javascript"> var qrcode = new QRCode(document.getElementById("qrcode"), { text: "http://jindo.dev.naver.com/collie", width: 128, height: 128, colorDark : "#000000", colorLight : "#ffffff", correctLevel : QRCode.CorrectLevel.H }); </script>
经过了解该组件的使用,咱们能够在项目中增长一个实际的代码进行测试,以下所示。
<table border='0' width='100%'> <tr> <td> 设备二维码(9001):<br /> <div id="imgDevice9001"></div> </td> <td> 设备二维码(9002):<br /> <div id="imgDevice9002"></div> </td> <td> 设备二维码(9003):<br /> <div id="imgDevice9003"></div> </td> </tr> <tr style="height:20px"><td colspan="3"></td></tr> ...... </table>
具体咱们能够利用JS动态生成相关的二维码。
//设备图片二维码 for (var i = 9001; i < 9010; i++) { var url = "http://www.iqidi.com/H5/device?devicecode=" + i; //使用jquery.qrcode的作法 //$("#imgDevice" + i).qrcode({ width: 100, height: 100, text: url }); //$("#imgDevice" + i).css("height", "100px"); //使用qrcodejs的作法 var qrcode = new QRCode(document.getElementById("imgDevice" + i), { text: url, width: 128, height: 128, colorDark: "#000000", colorLight: "#ffffff", correctLevel: QRCode.CorrectLevel.H }); }
最后界面生成的二维码以下所示。
介绍我二维码和条形码的生成,关于它们的打印,能够利用我介绍过的CLODOP进行打印处理,须要了解能够参考下随笔《基于MVC+EasyUI的Web开发框架经验总结(16)--使用云打印控件C-Lodop打印页面或套打报关运单信息》
咱们在这里介绍的打印,也是基于这个控件的打印处理的。
固然,若是打印,也是能够利用PrintThis这个组件进行处理的(详细能够参考随笔《基于Metronic的Bootstrap开发框架经验总结(9)--实现Web页面内容的打印预览和保存操做》),不过整体效果没有上面的CLODOP的打印效果佳。
打印JS代码以下所示,能够采用下面两个函数的其中之一进行处理。
//使用表格格式化输出 function PrintBarcodeWithTable() { LODOP = getLodop(); LODOP.PRINT_INIT("条码_格式化输出"); var strHTML = "<table border='0' width='100%' >"; strHTML = strHTML + "<tr><td>"; strHTML = strHTML + $("#barDiv1").html(); strHTML = strHTML + "</td></tr>"; strHTML = strHTML + "<tr><td>"; strHTML = strHTML + $("#barDiv2").html(); strHTML = strHTML + "</td></tr>"; strHTML = strHTML + "<tr><td>"; strHTML = strHTML + $("#barDiv3").html(); strHTML = strHTML + "</td></tr>"; LODOP.ADD_PRINT_TABLE(88, 200, 700, 900, strHTML); LODOP.SET_SHOW_MODE("PREVIEW_IN_BROWSE", 1); LODOP.PREVIEW(); } //使用分页输出 function PrintBarcodeWithPaging() { LODOP = getLodop(); LODOP.PRINT_INIT("条码_分页输出"); LODOP.ADD_PRINT_HTM(100, 100, 600, 800, $("#barDiv1").html()); LODOP.NewPage(); LODOP.ADD_PRINT_HTM(100, 100, 600, 800, $("#barDiv2").html()); LODOP.NewPage(); LODOP.ADD_PRINT_HTM(100, 100, 600, 800, $("#barDiv3").html()); LODOP.NewPage(); LODOP.SET_SHOW_MODE("PREVIEW_IN_BROWSE", 1); LODOP.PREVIEW(); }
条码的打印效果以下所示。
而打印二维码的JS代码以下所示。
//打印二维码 function PrintQrcode2() { CreatePrintData($("#qrcode").html()); LODOP.SET_SHOW_MODE("PREVIEW_IN_BROWSE", 1); LODOP.PREVIEW(); } //打印数据构建 function CreatePrintData(html) { LODOP = getLodop(); LODOP.PRINT_INIT(""); //var strBodyStyle = "<link type='text/css' rel='stylesheet' href='/Content/Themes/Default/style.css' />"; var strBodyStyle = "<style><!--table { border:1;background-color: #CBCBCC } td {border: 1; }"; strBodyStyle += " th { background-color:#F1F1F3;padding-left:5px;border:1}--></style>"; var strFormHtml = strBodyStyle + "<body>" + html + "</body>"; LODOP.ADD_PRINT_HTM(20, 40, 710, 900, strFormHtml); LODOP.PREVIEW(); }
获得的二维码打印效果以下所示。
最终完成了这个关于条形码、二维码的动态生成,以及图形打印的相关操做了。整个模块的界面以下所示。
关于条形码、二维码的处理,咱们这里引入的条形码组件JsBarcode和二维码组件qrcodejs是很是不错的开源JS组件,知足了咱们大多数的要求,并且使用方便、简洁,但愿这些内容可以给你的项目提供灵感及用处。