一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

javascript下用ActiveXObject控件替換word書簽,將內容導出到word后打印第1/2頁

最近有需求將數據導出到word里,然后編輯打印。
想過幾種方案:
1.使用jacob。
2.使用apache的poi。
3.使用itext。
由于時間比較緊,沒多的時候去學習研究上述工具包,現在用Javascript操作ActiveXObject控件,用替換word模板中的書簽方式解決。

前提條件:
1.瀏覽器安全級別降低,可以使用ActiveXObject控件。

2.裝有office word。

目前實現了替換單個書簽,多行表格書簽,和圖片,基本上滿足需求。不過還有很多操作word的使用方法不太清楚,網上大部分都使用的VB,有不清楚的地方,大家可以交流。

下面說一下我的設計實現思路:

首先當然是定義word模板,在需要替換的地方加上標簽。 菜單-插入-書簽,輸入屬性名,如year,date,pic1,voList等等。
打印頁面:
需要把打印的數據從后臺取出,以單個vo(一個對象)為一組,或以voList(對象的列表集合)為一組 組織好頁面上 再得到這些數據后進行替換。
數據組織形式如下:
<div id="export2word">
 <form id="singleVo" name="singleVo">
  <textarea name="jcxcrs" style="display:none"><c:out value="${zywstjfxbgVO.jcxcrs }"/></textarea>
  <textarea name="xcjhl" style="display:none"><c:out value="${zywstjfxbgVO.xcjhl }"/></textarea>
  <textarea name="tbjcxcrs" style="display:none"><c:out value="${tbjcxcrs }"/></textarea>
  <textarea name="tptest" style="display:none">../zwgl/zw008-ZwMkjbxxCTRL-showWxytp.png?xh=3041</textarea>
 </form>

 <c:forEach var="mxvo" items="${jgList}" varStatus="s">
  <form name="mxvoForm">
   <!-- 注:這里的寬度設置為表格單元格寬度(厘米*100)-->
   <textarea name="tbjcmcrs" style="width:349;display:none"><c:out value="${mxvo.tbjcmcrs }"/></textarea>
   <textarea name="tbjcmcrsbl" style="width:270;display:none"><c:out value="${mxvo.tbjcmcrsbl }"/></textarea>
   <textarea name="tbjcxcrs" style="width:477;display:none"><c:out value="${mxvo.tbjcxcrs}"/></textarea>
   <textarea name="tbjcxcrsbl" style="display:none"><c:out value="${mxvo.tbjcxcrsbl }"/></textarea>
  </form>
 </c:forEach>
</div>

使用:
<input type="button" id="select2" name="select2" class="button" value="導出數據" onclick="print2doc();">

<script type="text/Javascript" src="../public/scripts/export2word.js"></script>
<script type="text/Javascript">
function print2doc(){
    //參數為模板(與頁面的相對)路徑
   var word = new WordApp("test.doc");
    //參數為form名,vo中需要添加的屬性(為空時form里所有屬性)
   var vo = word.getSingleVo("singleVo",["jcxcrs","xcjhl","tbjcxcrs"]);
   //var vo = word.getSingleVo("singleVo");
    //組織成的圖片vo
   var tpvo = word.getSingleVo("singleVo",["tptest"]);
    //參數為 form名,需要添加的屬性(順序為生成表格列的順序,為空時form里的所有屬性和順序)
   var voList = word.getVoList("mxvoForm",["tbjcmcrs","tbjcmcrsbl","tbjczsrs"]);
   //var voList = word.getVoList("mxvoForm");
   //替換普通書簽
   word.replaceBookmarkUsevo(vo);
    //替換圖片書簽
   word.replaceBookmarkUsepicvo(tpvo);
    //替換書簽jgList,畫出表格形成多行數據。
   word.replaceBookmarkUsevolist("jgList",voList);
    //文檔可見
   word.wordObj.visible=true;
   //word.closeApp();
  }
</script>
注意:
替換圖片的值需要解釋一下:
1.可以設為相對本頁面的路徑如../zbgl/abc.png
2.如果是輸出流,則需要把請求輸出流的url映射成以圖片格式結尾的。如/.../abc.do?id=123換成/../abc.png?id=123
可以在web.xml里配一個servlet,如以*.png的請求轉成.do的。如:

public class PngDispatcherServlet extends HttpServlet {

 private static final long serialVersionUID = 6230740581031996144L;

  public void init() throws ServletException {

 } 

    public void doPost(HttpServletRequest request, HttpServletResponse response) throws
        ServletException, IOException {
     doGet(request, response);
    }

    public void doGet(HttpServletRequest request, HttpServletResponse response) throws
        ServletException, IOException {

     //StringBuffer url = request.getRequestURL();
     StringBuffer url = new StringBuffer(request.getRequestURI());
     if(request.getQueryString() != null) { 
         url.append('?'); 
         url.append(request.getQueryString()); 
       } 
     String newUrl = url.toString().replaceAll(".png", ".do");
     ServletContext sc = getServletContext();
     RequestDispatcher rd = sc.getRequestDispatcher(newUrl); //定向的頁面
     rd.forward(request, response); 
   } 
}

JavaScript技術javascript下用ActiveXObject控件替換word書簽,將內容導出到word后打印第1/2頁,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 在线看福利片 | 国产在线啪 | 成人在线免费小视频 | 国产精品中文 | 日本网址在线观看 | 九一视频在线免费观看 | 国产成人精品一区二区不卡 | 国产最新网址 | 在线视频一区二区三区四区 | 久久国产加勒比精品无码 | 国产原创中文字幕 | 国产美女精品一区二区三区 | 亚洲高清一区二区三区四区 | 亚洲一区二区三 | 成 人 黄 色视频免费播放 | 国语对白免费观看网址 | 久久精品国产亚洲精品 | 中文字幕123| 欧美成人伊人十综合色 | 四虎4hu亚洲精品 | 91狠狠操| 日本一区二区日本免费 | 一道本色 | 日本精品视频一区二区 | 999热精品这里在线观看 | 欧美成人午夜视频 | 99久久久久国产精品免费 | 国产成人精品日本亚洲网址 | 欧洲精品码一区二区三区免费看 | 精品视频一区二区 | 国产高清美女一级a毛片 | 国产精品亚洲国产 | 四虎在线视频免费观看 | 深爱五月激情 | 久久精品国产无限资源 | 欧美日韩亚洲另类人人澡 | 日韩亚洲欧洲在线rrrr片 | 午夜久久久精品 | 久久国产影视免费精品 | 91高清视频在线 | 国产91网站在线观看免费 |