天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

javascript下用ActiveXObject控件替換word書(shū)簽,將內(nèi)容導(dǎo)出到word后打印第1/2頁(yè)

最近有需求將數(shù)據(jù)導(dǎo)出到word里,然后編輯打印。
想過(guò)幾種方案:
1.使用jacob。
2.使用apache的poi。
3.使用itext。
由于時(shí)間比較緊,沒(méi)多的時(shí)候去學(xué)習(xí)研究上述工具包,現(xiàn)在用Javascript操作ActiveXObject控件,用替換word模板中的書(shū)簽方式解決。

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

2.裝有office word。

目前實(shí)現(xiàn)了替換單個(gè)書(shū)簽,多行表格書(shū)簽,和圖片,基本上滿足需求。不過(guò)還有很多操作word的使用方法不太清楚,網(wǎng)上大部分都使用的VB,有不清楚的地方,大家可以交流。

下面說(shuō)一下我的設(shè)計(jì)實(shí)現(xiàn)思路:

首先當(dāng)然是定義word模板,在需要替換的地方加上標(biāo)簽。 菜單-插入-書(shū)簽,輸入屬性名,如year,date,pic1,voList等等。
打印頁(yè)面:
需要把打印的數(shù)據(jù)從后臺(tái)取出,以單個(gè)vo(一個(gè)對(duì)象)為一組,或以voList(對(duì)象的列表集合)為一組 組織好頁(yè)面上 再得到這些數(shù)據(jù)后進(jìn)行替換。
數(shù)據(jù)組織形式如下:
<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">
   <!-- 注:這里的寬度設(shè)置為表格單元格寬度(厘米*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="導(dǎo)出數(shù)據(jù)" onclick="print2doc();">

<script type="text/Javascript" src="../public/scripts/export2word.js"></script>
<script type="text/Javascript">
function print2doc(){
    //參數(shù)為模板(與頁(yè)面的相對(duì))路徑
   var word = new WordApp("test.doc");
    //參數(shù)為form名,vo中需要添加的屬性(為空時(shí)form里所有屬性)
   var vo = word.getSingleVo("singleVo",["jcxcrs","xcjhl","tbjcxcrs"]);
   //var vo = word.getSingleVo("singleVo");
    //組織成的圖片vo
   var tpvo = word.getSingleVo("singleVo",["tptest"]);
    //參數(shù)為 form名,需要添加的屬性(順序?yàn)樯杀砀窳械捻樞颍瑸榭諘r(shí)form里的所有屬性和順序)
   var voList = word.getVoList("mxvoForm",["tbjcmcrs","tbjcmcrsbl","tbjczsrs"]);
   //var voList = word.getVoList("mxvoForm");
   //替換普通書(shū)簽
   word.replaceBookmarkUsevo(vo);
    //替換圖片書(shū)簽
   word.replaceBookmarkUsepicvo(tpvo);
    //替換書(shū)簽jgList,畫(huà)出表格形成多行數(shù)據(jù)。
   word.replaceBookmarkUsevolist("jgList",voList);
    //文檔可見(jiàn)
   word.wordObj.visible=true;
   //word.closeApp();
  }
</script>
注意:
替換圖片的值需要解釋一下:
1.可以設(shè)為相對(duì)本頁(yè)面的路徑如../zbgl/abc.png
2.如果是輸出流,則需要把請(qǐng)求輸出流的url映射成以圖片格式結(jié)尾的。如/.../abc.do?id=123換成/../abc.png?id=123
可以在web.xml里配一個(gè)servlet,如以*.png的請(qǐng)求轉(zhuǎn)成.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); //定向的頁(yè)面
     rd.forward(request, response); 
   } 
}

JavaScript技術(shù)javascript下用ActiveXObject控件替換word書(shū)簽,將內(nèi)容導(dǎo)出到word后打印第1/2頁(yè),轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 日韩一区二区三区精品 | 国产AV一区二区三区传媒 | 国内九一激情白浆发布 | 蜜桃成熟时2在线观看完整版hd | 工口肉肉彩色不遮挡 | 亚洲九九精品 | 伦理片在线3348 | 精品人妻一区二区三区视频53 | 青春草久久 | 无码AV精品一区二区三区 | 色99久久久久高潮综合影院 | 女人把腿张开叫男人桶免费视频 | 胸大的姑娘中文字幕视频 | 一边吃奶一边添P好爽故事 一边吃奶一边啪啪真舒服 一本之道加勒比在线观看 一本之道高清在线观看一区 | 国产成人在线免费 | 哪里能看毛片 | 中文字幕在线免费视频 | 人人干人人插 | 人妻免费久久久久久久了 | 亚洲一区二区女搞男 | 一本二卡三卡四卡乱码麻豆 | 中字幕视频在线永久在线 | 红尘影院在线观看 | 看免费人成va视频全 | V8成品人视频 | 国产精品成人A蜜柚在线观看 | 戳女人屁股流水羞羞漫画 | 午夜福利网国产A | 秋霞网站一级一片 | 国产又湿又黄又硬又刺激视频 | 98久久人妻无码精品系列蜜桃 | 99国内精品 | 男女全黄h全肉细节文 | 92看看福利午夜影院 | 日本久久道一区二区三区 | 亚洲精品国偷拍自产在线观看蜜臀 | 绑着男军人的扒开内裤 | 国产精品1卡二卡三卡四卡乱码 | XXOO麻豆国产在线九九爱 | 色欲AV久久综合人妻蜜桃 | caoporn免费视频在线 |