`
jetway
  • 浏览: 488918 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

用ActiveXObject控件替换word书签,将内容导出到word后打印

    博客分类:
  • java
阅读更多
用ActiveXObject控件替换word书签,将内容导出到word后打印
最近有需求将数据导出到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);
   }
}

export2word.js代码:

/**
* <p> Title: 用word书签替换的方式将内容导出到word</p>
* <p> Description: **</p>
* <p> Copyright: Copyright (c) 2007-2010 </p>
* <p> Company: ** </p>
* @author zhu
* @version 1.0
*/
var baseVoListObj = function(){
this.volist = new Array();
this.cols = new Array();
this.widths = new Array();
}

var WordApp = function(wordTplPath){
var wordObj = new ActiveXObject("Word.Application");
if(wordObj==null){
  alert( "不能创建Word对象!");
}  
wordObj.visible=false;
this.wordObj = wordObj;
this.docObj = this.wordObj.Documents.Open(getRootPath() + wordTplPath);
}

WordApp.prototype.closeApp = function(){
if (this.wordObj !=null){
   this.wordObj.Quit();
}
}

WordApp.prototype.replaceBookmark = function(strName,content,type){
if (this.wordObj.ActiveDocument.BookMarks.Exists(strName)) {
  if (type != null && type == "pic") {//图片
            var objDoc = this.wordObj.ActiveDocument.BookMarks(strName).Range.Select();
            var objSelection = this.wordObj.Selection;
            objSelection.TypeParagraph();
   //alert(getRootPath()+content);
            var objShape = objSelection.InlineShapes.AddPicture(getRootPath()+content);
  }
  else {
   this.wordObj.ActiveDocument.BookMarks(strName).Range.Select();
   this.wordObj.Application.selection.Text = content;
  }
}else{
  //alert("标签不存在");
}
}

WordApp.prototype.replaceBookmarkUsevo = function(voObj){
if(typeof voObj != "object"){
  alert("请输入正确的vo对象");
}else{
  for(var i in voObj){
   this.replaceBookmark(i,voObj[i]);
  }
}
}

WordApp.prototype.replaceBookmarkUsepicvo = function(voObj){
if(typeof voObj !="object"){
  alert("请输入正确的vo对象");
}else{
  for(var i in voObj){
   this.replaceBookmark(i,voObj[i],"pic");
  }
}
}

WordApp.prototype.replaceBookmarkUsevolist = function(strName,voListObj){
if(typeof voListObj != "object"){
  alert("参数应为数组类型");
}else{
  var row = voListObj.volist.length;
  var col = voListObj.cols.length;
  var objDoc = this.wordObj.ActiveDocument.BookMarks(strName).Range;
  var objTable = this.docObj.Tables.Add(objDoc,row,col) ;//插入表格
  for (var i = 0; i < row; i++) {
   for(var j=0; j<col; j++){
    //todo 列表里面如果有图片类型不支持,需要判断
    objTable.Cell(i+1,j+1).Range.InsertAfter(voListObj.volist[i][voListObj.cols[j]]);
    var width = voListObj.widths[j];
    if(width.indexOf("px")!=-1){
     objTable.Cell(i+1,j+1).Width = (width.substr(0,width.length-2)/100) * 28.35;//1厘米=28.35磅
    }  
   }
  }
  //objTable.AutoFormat(16);
  objTable.Borders.InsideLineStyle = 1
        objTable.Borders.OutsideLineStyle = 0;
}
}

WordApp.prototype.getSingleVo = function(formName,arrayObj){//第二个参数可以为空,不填时默认为表单里的所有元素
var formObj = document.forms[formName];
if(formObj!=null){
  if(arrayObj!=null){
   if(arrayObj instanceof Array){
    var vo = {};
    for(var i=0;i<arrayObj.length;i++){
     if(formObj.elements[arrayObj[i]]!= undefined ){
      eval("vo." + arrayObj[i] + " = formObj.elements[arrayObj[i]].value;");
     }   
    }
    //alert(objToString(vo));
    return vo;
   }else{
    alert("弟二个参数应为数组类型"); 
   }
  }else{
   var vo = {};
   for(var i=0;i<formObj.elements.length;i++){
    eval("vo." + formObj.elements[i].name + " = formObj.elements[i].value;");
   }
   return vo;
  }
}else{
  alert("第一个参数表示的表单不存在");
  return null;
}
}

WordApp.prototype.getVoList = function (formName,arrayObj){//表单名,属性数组(可以为空)
//var formArray = document.forms[formName];
var formArray = document.getElementsByName(formName);
if (formArray != null) {
  if (arrayObj instanceof Array) {
   var voListObj = new baseVoListObj();
   for(var i=0;i<formArray.length;i++){  
    var vo = {};
    for(var j=0;j<arrayObj.length;j++){
     if(formArray[i].elements[arrayObj[j]]!= undefined ){
      eval("vo."+arrayObj[j]+" = formArray[i].elements[arrayObj[j]].value;");     
      if(i==0){//第一次的时候定义有效属性和宽度
       voListObj.cols.push(arrayObj[j]);
       voListObj.widths.push(formArray[i].elements[arrayObj[j]].style.width);
      }   
     }   
    }
    voListObj.volist.push(vo);
   }
   return voListObj;
  }else{
   var voListObj = new baseVoListObj();
   for(var i=0;i<formArray.length;i++){  
    var vo = {};
    for(var j=0;j<formArray[i].elements.length;j++){
     eval("vo."+formArray[i].elements[j].name+" = formArray[i].elements[j].value;");
     if(i==0){//第一次的时候定义宽度
      voListObj.cols.push(formArray[i].elements[j].name);
      voListObj.widths.push(formArray[i].elements[j].style.width);
     }  
    }
    voListObj.volist.push(vo);
   }
   return voListObj;
  } 
}else{
  return null;
}
}

function objToString(obj){
if(obj instanceof Array){
  var str="";
  for(var i=0;i<obj.length;i++){
   str+="[";
   for(var j in obj[i]){
    str+=j+"="+obj[i][j]+" ";
   }
   str+="]"n"; 
  }
  return str;
}else if(obj instanceof Object){
  var str="";
  for(var i in obj){
   str+=i+"="+obj[i]+" ";
  }
  return str; 
}
}

function getRootPath()
{
var location=document.location;
if ("file:" == location.protocol) {
  var str = location.toString();
  return str.replace(str.split("/").reverse()[0], "");
}
var pathName=location.pathname.split("/");
return location.protocol+"//"+location.host+"/"+pathName[1]+"/";
}
分享到:
评论

相关推荐

    javascript下用ActiveXObject控件替换word书签,将内容导出到word后打印第1/2页

    最近有需求将数据导出到word里,然后编辑打印。 想过几种方案: 1.使用jacob。 2.使用apache的poi。 3.使用itext。 由于时间比较紧,没多的时候去学习研究上述工具包,现在用javascript操作ActiveXObject控件,用...

    js导出到word并产生目录

    2. **插入数据**:遍历表单元素,获取需要导出的数据,通过Ajax调用后端接口获取JSP页面的内容,然后将其插入到Word文档中。 3. **格式化文本**:设置字体大小、加粗等样式属性,确保Word文档的美观性。 4. **添加...

    利用Activex控件将html的String导出到word和excel

    ### 利用Activex控件将html的String导出到Word和Excel 在日常工作中,我们经常需要将网页中的数据导出为Word或Excel格式,以便进行进一步的数据处理或者分享给其他用户。本文将详细介绍如何使用ActiveX控件实现这一...

    利用js导出Web页面内容到Word、Excel

    ### 使用JavaScript将Web页面内容导出至Word与Excel #### 概述 本文将详细介绍如何通过JavaScript(简称JS)实现在Web页面上将特定内容导出到Microsoft Word和Excel的功能。这种方法非常适合那些需要快速将网页...

    js直接调用word文档打印word

    例如,使用Microsoft Graph API,你可以获取Word文档的内容并在浏览器中显示,然后提供一个打印按钮让用户直接打印。 2. **文件上传和服务器处理**:用户可以通过HTML5的File API选择本地的Word文档上传到服务器。...

    js操作word打印

    如果需要在Word中动态创建表格并填充数据,可以使用Word的对象模型。例如,以下代码创建一个3行5列的表格,并在其中填充数据: ```javascript var wordApp = new ActiveXObject("Word.Application"); var doc = ...

    将html网页上的内容导出为word文件

    可以提取出页面的主要样式,然后使用Word兼容的样式规则。这通常涉及遍历`&lt;style&gt;`标签,提取出内联样式,并将其转化为Word样式。 3. **创建Word文档**:有几种方法可以创建Word文档。一种是利用Microsoft的...

    WEB页面导出为WORD、EXCEL文档的方法(源代码)

    本文将详细介绍如何使用 ASP 语言将 WEB 页面导出为 WORD、EXCEL 文档,包括使用 JavaScript 语言将表格内容导出到 EXCEL 文档中,并使用 ActiveXObject 对象来实现 WORD 文档的导出。 首先,在 HTML 代码中,我们...

    导出到word文件的js脚本

    在Web开发过程中,常常需要将网页中的数据导出为其他格式,如PDF或Word文档,以便用户进行保存或打印。其中,将HTML内容转换并导出为Word文档的需求较为常见。本文将详细介绍一个使用JavaScript实现的导出到Word文件...

    js导出word

    在网页中实现导出Word文档通常涉及到两个主要步骤:首先,需要将网页中的内容复制到剪贴板;其次,通过调用Microsoft Word应用程序创建一个新的Word文档,并将剪贴板中的内容粘贴到新文档中。整个过程可以通过...

    js按钮导出word

    在JavaScript中,将网页内容导出...总的来说,通过JavaScript将网页内容导出为Word文件涉及对DOM的操作、ActiveXObject的使用以及可能的数据转换。这种方法虽然有一定的局限性,但在某些场景下仍是一种有效的解决方案。

    javaweb页面导出word集合,转

    在Java Web开发中,将网页内容导出为Word文档是一种常见的需求,通常用于报表生成、报告编写等场景。这个过程涉及到对HTML内容的处理以及Word文档的生成。以下是一些关键知识点和实现方法: 1. **使用ActiveXObject...

    js调用word 直接打印预览功能

    本文将深入解析如何利用JavaScript(JS)调用Microsoft Word来实现文档的直接打印预览功能,这不仅能够提升用户体验,还能增强Web应用的功能性。 ### 关键知识点 #### 1. JavaScript与ActiveX对象 在Windows环境...

    JavaScript将Web页面内容导出到Word及Excel的方法

    1. **AllAreaExcel** 函数用于导出整个表格(ID为"PrintA")的内容到Excel。首先,创建一个`Excel.Application`对象实例(oXL),然后添加一个新的工作簿(oWB),并获取其活动工作表(oSheet)。接着,利用`...

    jsp 导出为Word

    在日常工作中,经常需要将网页上的数据导出到其他格式,如Word或Excel等,以便于进一步处理或分享。本文主要介绍如何利用JSP技术将页面中的表格(Table)数据导出为Word文档。 #### 基本原理与实现步骤 要实现这一...

    最新实用的web打印控件

    在本篇中,我们将深入探讨web打印控件的核心概念、其工作原理以及如何使用LODOP控件来实现高效打印。 首先,我们需要了解什么是Web打印控件。Web打印控件是一种JavaScript或ActiveX插件,它可以嵌入到网页中,使得...

    ie浏览器 js调用 ocx 异步打印pdf、图片控件

    JavaScript可以使用`FileReader` API读取本地文件,然后将数据传递给OCX控件进行打印。 总的来说,这个解决方案提供了一种在IE浏览器中通过JavaScript控制OCX控件实现异步打印PDF和图片的方法,特别适合自助终端等...

    JSP中表单嵌入到WORD中打印函数

    在IT领域,特别是Web开发与办公自动化集成方面,将网页中的数据导出并整合到其他文档格式(如Microsoft Word)中是一项非常实用的功能。本文旨在详细介绍如何利用JavaScript结合JSP技术实现这一目标,即“JSP中表单...

    JS 导出页面可选区域到Word文档

    使用Word文档的`Paste`方法将之前复制的内容粘贴进来,并显示Word应用程序窗口。 - **粘贴至Excel文档**: ```javascript oSheet.Paste(); oXL.Visible = true; ``` 类似地,使用Excel的`Paste`方法将复制...

Global site tag (gtag.js) - Google Analytics