zoukankan      html  css  js  c++  java
  • 【JS新手教程】LODOP打印复选框选中的任务或页数

    之前的博文:【JS新手教程】LODOP打印复选框选中的内容
    关于任务:Lodop打印语句最基本结构介绍(什么是一个任务)
    关于本文用到的JS的eval方法:JS-JAVASCRIPT的eval()方法
    该文用的是不同checkbox,对应不同的value值,不同的value是不同的打印项语句,也可以不用value属性,直接不同checkbox对不同字符串,然后加载执行该字符串,用eval方法执行里面的JS语句。

    这里面有两种输出方式,选择三个复选框,每个一个任务输出,输出三个任务,该文用xps虚拟打印机测试,输出为三个xps文件。第二种循环newpage,一个任务多页,输出一个xps文件,该文件里有三页。
    INIT和PRINT放在循环之外,里面用newpage分隔,一个任务打印多页。(三个复选框都选,就是打印三页)
    INIT和PRINT放在循环之内,不加分页,一个任务一页,打印三个任务。(三个复选框都选,就是打印三个任务)

    代码:

    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>WEB打印控件LODOP</title>
    <script language="javascript" src="LodopFuncs.js"></script>
    </head>
    <body>
    输入选择人名:<input type="text" id="T1"><br>
    <hr>
    选择第一组:
    <input type="checkbox" id="CK0" name="hob" value="">内容加矩形
    <input type="checkbox" id="CK1" name="hob" value="">条码和椭圆
    <input type="checkbox" id="CK2" name="hob" value="">二维码和直线
    <hr>
    <div id="hom">
    选择第二组:
    <input type="checkbox" value="">内容加矩形
    <input type="checkbox" value="">条码和椭圆
    <input type="checkbox" value="">二维码和直线
    <hr>
    </div>
    <a href="javascript:prn1_preview()">第一组的选择,分任务输出选择的多个任务</a><br>
    <a href="javascript:prn2_preview()">第二组的选择,一个任务输出多页</a><br>
    <script language="javascript" type="text/javascript">   
            var LODOP; //声明为全局变量 
    
        function prn1_preview() {
               document.getElementById("CK0").value=
       "LODOP.ADD_PRINT_TEXT(37,92,58,23,'内容1');LODOP.ADD_PRINT_RECT(73,77,100,60,0,1);LODOP.ADD_PRINT_TEXT(92,186,94,20,'内容1');"; 
       document.getElementById("CK1").value="        LODOP.ADD_PRINT_SHAPE(5,37,94,100,60,0,1,'#FFFF80');LODOP.ADD_PRINT_BARCODE(105,105,100,60,'Code39','123456789012');"; 
       document.getElementById("CK2").value="LODOP.ADD_PRINT_BARCODE(51,123,140,81,'QRCode','123456789012');LODOP.ADD_PRINT_LINE(130,74,136,243,0,6);"; 
            LODOP=getLodop(); 
            obj_allhob=document.getElementsByName("hob");
        for (i=0;i<obj_allhob.length;i++) {
                if (document.getElementById("CK"+i).checked) {
                    LODOP.PRINT_INIT("");
                    LODOP.SET_PRINT_PAGESIZE(1,600,800,"");
                    eval(document.getElementById("CK"+i).value);
                    LODOP.PRINT();
                }             
            }
        };
            function prn2_preview() {
            var div_hom=document.getElementById("hom");
            var obj_allhom=div_hom.getElementsByTagName("input");    
            obj_allhom[0].value=
       "LODOP.ADD_PRINT_TEXT(37,92,58,23,'内容1');LODOP.ADD_PRINT_RECT(73,77,100,60,0,1);LODOP.ADD_PRINT_TEXT(92,186,94,20,'内容1');"; 
       obj_allhom[1].value="        LODOP.ADD_PRINT_SHAPE(5,37,94,100,60,0,1,'#FFFF80');LODOP.ADD_PRINT_BARCODE(105,105,100,60,'Code39','123456789012');"; 
       obj_allhom[2].value="LODOP.ADD_PRINT_BARCODE(51,123,140,81,'QRCode','123456789012');LODOP.ADD_PRINT_LINE(130,74,136,243,0,6);"; 
            LODOP=getLodop();        
            LODOP.PRINT_INIT("");
            LODOP.SET_PRINT_PAGESIZE(1,600,800,"");
        for (i=0;i<obj_allhom.length;i++) {
                if (obj_allhom[i].checked) {
                    LODOP.NEWPAGE();        
                    eval(obj_allhom[i].value);
                }             
            }
             LODOP.PRINT();
        };
    </script>     
    </body>

    图示:

  • 相关阅读:
    JAVA安装
    capture格式布局
    CSS样式表
    进制的转换
    CentOs7设置主机名称,以及主机名称和ip的对应关系
    CentOS7中NAT网卡设置静态IP
    CentOs7安装配置JDK
    基于Go语言构建区块链:part5
    基于Go语言构建区块链:part4
    BoltDB使用笔记
  • 原文地址:https://www.cnblogs.com/huaxie/p/10837474.html
Copyright © 2011-2022 走看看