溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

ActiveX控件的使用-js實現(xiàn)打印超市小票功能代碼詳解

發(fā)布時間:2020-09-25 15:08:03 來源:腳本之家 閱讀:406 作者:鄭州的文武 欄目:web開發(fā)

·應(yīng)客戶的需求= = ,要在網(wǎng)頁端實現(xiàn)打印小票的功能

·先來一張打印出的小票效果圖(合計明顯不對,因為有修改訂單功能,請各位忽略)

ActiveX控件的使用-js實現(xiàn)打印超市小票功能代碼詳解

用什么方法實現(xiàn)呢:

我想應(yīng)該是有三種吧

1.用第三方的瀏覽器控件(這個好似比較方便,我的老師也是這樣建議我)向大家推薦一個 Lodop打印控件

2.用CSS寫好模板,然后直接用頁面打印的方法(應(yīng)該是這樣吧)

以上兩種還沒有嘗試,這兩天陸續(xù)嘗試)

3.用微軟自己的ActiveX控件(ActiveX控件可以實現(xiàn)調(diào)用本地的文件等操作(之前試過調(diào)用cmd,實現(xiàn)shutdown -s -t,在網(wǎng)頁控制電腦的定時關(guān)機))

當然這種方法的缺點也很明顯:限操作系統(tǒng)-因為是微軟的東西只能Windows下,限瀏覽器-因為ActiveX也只能在IE瀏覽器下。所以局限性比較大

實現(xiàn)過程:

1.編輯『word小票模板』,要用到word中『書簽』這個工具(通過『書簽』的定位,js就可以操作word在『書簽』指定的位置進行 修改、寫入內(nèi)容)

2.在js對word模板進行 打開、賦值、打印操作

一、編輯『word小票模板』

    1.以word2007為例,首先排好大致的樣式

ActiveX控件的使用-js實現(xiàn)打印超市小票功能代碼詳解

二、js

直接上源代碼吧:

<input type="button" value="toPrinter " onclick="viewToWord();" /> 
- Hide code
function viewToWord() {
    //當前時間
    var Time;
    var today = new Date();
    Time = today.toLocaleString();
    
    try { 
      // 創(chuàng)建ActiveXObject對象 
      wdapp = new ActiveXObject("Word.Application"); 
    } 
    catch (e) { 
      console.log("無法調(diào)用Office對象,!", e) 
      wdapp = null; 
      return; 
    }
    wdapp.Documents.Open("f:\\PrinterTemplate1.doc"); //打開本地(客戶端)word模板
    wddoc = wdapp.ActiveDocument; 
    wddoc.Bookmarks("OrderNum").Range.Text = "201509080959" + "\n";
    wddoc.Bookmarks("OrderName").Range.Text = "鄭斌" + "\n"; 
    wddoc.Bookmarks("OrderAddress").Range.Text = "www.cnblogs.com/zhengbin" + "\n";
    wddoc.Bookmarks("OrderPhoneNum").Range.Text = "QQ:1746788394" + "\n";
    wddoc.Bookmarks("OrderDaocanTime").Range.Text = "10:00-11:00" + "\n";
    wddoc.Bookmarks("OrderTime").Range.Text = "09-08 10:15";
    //添加表格
    var myTable = wddoc.Tables.Add (wddoc.Bookmarks("OrderCart").Range,3,3);//(賦值區(qū)域,行數(shù),列數(shù))
    //隱藏邊框
    var table=wdapp.ActiveDocument.Tables(1);
    table.Borders(-1).LineStyle=0;
    table.Borders(-2).LineStyle=0;
    table.Borders(-3).LineStyle=0;
    table.Borders(-4).LineStyle=0;
    table.Borders(-5).LineStyle=0;
    table.Borders(-6).LineStyle=0;
    for(i=1;i<=3;i++){//行
      //第一列
      with (myTable.Cell(i,1).Range){
        font.Size = 8;//調(diào)整字體大小
        InsertAfter("博客園"+i);//插入的內(nèi)容
      }
      //第二列
      with(myTable.Cell(i,2).Range){
        font.Size = 8;
        InsertAfter(i);
        ParagraphFormat.Alignment=1;//表格內(nèi)容對齊:0-左對齊 1-居中 2-右對齊
      }
      //第三列
      with(myTable.Cell(i,3).Range){
        font.Size = 8;
        InsertAfter("無價");
        ParagraphFormat.Alignment=2;
      }
    }
    wddoc.saveAs("f:\\PrinterTemp_cnblogs.doc"); //保存臨時文件word
    wddoc.Bookmarks("TotalPrice").Range.Text = "無價" + "\n";
    wddoc.Bookmarks("Time").Range.Text = Time; 
    //wdapp.ActiveDocument.ActiveWindow.View.Type = 1;
    wdapp.visible = false; //word模板是否可見 
    wdapp.Application.Printout(); //調(diào)用自動打印功能 
    wdapp.quit();
    wdapp = null; 
  }

最后:

ActiveX控件的使用-js實現(xiàn)打印超市小票功能代碼詳解

注意:

首先要調(diào)整好IE瀏覽器的 Internet選項-自定義級別(右邊『ActiveX控件和插件』下,能啟用的都啟用)

ActiveX控件的使用-js實現(xiàn)打印超市小票功能代碼詳解

『打印機脫機工作』一般是usb沒有插好,換插口,重啟打印機即可

有關(guān)ActiveX控件,簡單介紹下:ActiveX是Microsoft對于一系列策略性面向?qū)ο蟪绦蚣夹g(shù)和工具的稱呼,其中主要的技術(shù)是組件對象模型(COM)。在有目錄和其它支持的網(wǎng)絡(luò)中,COM變成了分布式COM(DCOM)。ActiveX 控件是用于互聯(lián)網(wǎng)的很小的程序,有時稱為插件程序。它們會允許播放動畫,或幫助執(zhí)行任務(wù),如在 Microsoft Update 安裝安全更新,因此可以增強您的瀏覽體驗。下面附本站免費下載地址:

OCX控件 [activex控件] 中文版

js之ActiveX控件使用說明 new ActiveXObject()

總結(jié)

以上就是本文關(guān)于ActiveX控件的使用-js實現(xiàn)打印超市小票功能代碼詳解的全部內(nèi)容,希望對大家有所幫助。如有問題可以隨時留言指出,感謝朋友們對本站的支持!

向AI問一下細節(jié)
AI