- 浏览: 92990 次
- 性别:
- 来自: 广州
最新评论
-
onleoneggp:
...
MyEclipse for spring 注册码 -
9976:
谢谢。可以用。
myeclipse 8.6 M1 注册码 收藏 -
greatghoul:
请教,如果xml是utf-8格式的,如何在属性中写入中文.
简单的Dom4j写入XML文件例子 -
fffddgx:
不错 有收获,谢谢
报错信息 -
lufei_vs:
引用
利用反射机制模拟Hibernate的Session
最近有需求将数据导出到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]+"/"; }
发表评论
-
Extjs 学习例子四(formPanel)
2010-12-13 17:29 1282Ext.onReady(function() ... -
struts从oracle获得图片并在jsp显示图片
2010-12-10 11:11 11301.OutputStream write Buffere ... -
MyEclipse for spring GEN
2010-10-09 12:30 951package Default; import java ... -
MyEclipse for spring 注册码
2010-10-09 09:08 6682注册名:leo 注册码:yLR8ZF-855555-6865 ... -
myeclipse 8.6 M1 注册码 收藏
2010-09-03 09:36 6260注册码: Subscriber:MaYong Sub ... -
用正则表达式加Javascript制作的好用简洁的输入框判断语句
2010-08-25 11:36 1181function UserEnter() { if(win ... -
去除多余字符的代码
2010-08-18 14:20 907import java.io.BufferedReader; ... -
写一个简单的java 定时器
2010-06-29 14:28 28771. 首先写一个获取时间,并格式化的操作类,使用单例模式 ... -
报错信息
2010-01-30 12:50 1005报错信息: java.lang.AbstractMeth ... -
利用反射机制模拟Hibernate的Session
2010-01-30 11:28 1463package com.quan.hibernate.mode ... -
JDBC连接模型
2010-01-21 10:21 939package TestConnection; impo ... -
TalkToMe 0.3
2010-01-20 00:44 835客户端 : import java.awt.Bord ... -
TalkToMe 0.1
2010-01-19 00:25 516客户端 : import java.awt.Bord ... -
Java 聊天器 beta1
2010-01-18 21:05 881import java.io.DataInputStream; ... -
MyEclipse 8 注册码
2010-01-17 22:28 1430import java.io.BufferedReader; ... -
Java 聊天器 (多线程模型)
2010-01-17 17:18 1841import java.io.DataInputStream; ... -
Socket 简单模型
2010-01-16 01:43 919服务器端: package step3_socket; ... -
Java 流的几个简单的例子
2010-01-10 19:57 1420package step2_io; import jav ... -
Java 初始化与清理
2010-01-08 00:16 1153调用顺序: JAVA类首次装入时,会对静态成员变量或方法进行一 ...
相关推荐
由于时间比较紧,没多的时候去学习研究上述工具包,现在用javascript操作ActiveXObject控件,用替换word模板中的书签方式解决。 前提条件: 1.浏览器安全级别降低,可以使用ActiveXObject控件。 2.装有office word...
### 利用Activex控件将html的String导出到Word和Excel 在日常工作中,我们经常需要将网页中的数据导出为Word或Excel格式,以便进行进一步的数据处理或者分享给其他用户。本文将详细介绍如何使用ActiveX控件实现这一...
### 使用JavaScript将Web页面内容导出至Word与Excel #### 概述 本文将详细介绍如何通过JavaScript(简称JS)实现在Web页面上将特定内容导出到Microsoft Word和Excel的功能。这种方法非常适合那些需要快速将网页...
本文将详细介绍一个使用JavaScript实现的导出到Word文件的功能脚本。 #### 二、关键技术点 ##### 1. JavaScript操作DOM元素 脚本中通过`getElementById`方法获取页面中的指定元素,例如: ```javascript var ...
根据给定的信息,本文将详细解释如何利用JavaScript(简称JS)技术实现在网页上导出Word文档的功能。此方法特别适用于那些希望在不离开当前Web应用程序的情况下为用户提供Word导出功能的开发人员。 ### 一、导出...
本文主要介绍如何使用JavaScript通过ActiveX对象来实现网页内容的导出,具体是将HTML表格数据导出到Excel和Word文档。ActiveX是Microsoft开发的一种技术,允许在浏览器环境中创建和运行控件,它在Internet Explorer...
用Javascript打印网页指定标签的内容是指在网页上选择指定的标签,然后将其内容导出到另一个页面上,最后进行打印的操作。这种方法可以灵活地控制打印的内容和格式。下面将详细介绍两种方法来实现这个功能。 方法1...
在日常工作中,经常需要将网页上的数据导出到其他格式,如Word或Excel等,以便于进一步处理或分享。本文主要介绍如何利用JSP技术将页面中的表格(Table)数据导出为Word文档。 #### 基本原理与实现步骤 要实现这一...
本文将详细介绍如何在ASP.NET中使用打印控件,以及通过JavaScript调用系统内置的打印方法。 首先,我们要明白,ASP.NET本身并不直接提供打印控件,但可以通过ActiveX或JavaScript来实现打印功能。在描述中提到的...
在JavaScript中,我们可以实现将HTML表格的内容导出到Excel文件,以及从Excel文件导入到HTML表格的功能。这两种操作对于数据的交互和管理非常有用,尤其是在客户端没有安装Excel软件的环境中。 首先,我们来看如何...
在JavaScript中操作Word和Excel可能涉及到的技术主要包括ActiveX对象、数据导出以及对象模型的使用。以下是对这些知识点的详细解释: 1. **ActiveX对象**:在上述代码中,`ActiveXObject` 是一个用于在Internet ...
在JavaScript中,将表格数据分组导出到Excel是一项常见的需求,这主要涉及到对HTML表格数据的处理以及利用ActiveXObject与Excel应用程序进行交互。以下是一个详细的步骤解释: 1. **获取表格数据**: - 首先,通过...
在MFC框架下,我们可以使用ActiveX控件或NPAPI(Netscape Plugin API)插件来创建这个中间层。ActiveX是微软开发的一种技术,允许在Web浏览器中嵌入和使用自定义的控件。NPAPI则是一种跨平台的API,尽管现在已经被弃...
在早期的 Internet Explorer 中被广泛使用,允许网页与浏览器之间的交互,如添加书签、导出收藏夹等功能。 **示例:** ```javascript window.external.AddFavorite(location.href, document.title); ``` 这段代码...
var fname = oXL.Application.GetSaveAsFilename("将table导出到excel.xls", "Excel Spreadsheets (*.xls), *.xls"); oWB.SaveAs(fname); ``` 7. **关闭工作簿和Excel应用**: 保存后,关闭工作簿和Excel应用...
1. **使用ActiveXObject对象导出到Excel** 2. **使用Apache POI写Excel** 3. **通过后台查询重新获取数据集写入Excel** 接下来,我们将对这三个知识点进行详细的介绍和分析。 ### 1. 使用ActiveXObject对象导出到...
本文将详细介绍几种使用JavaScript实现导出数据到Excel的方法,包括利用ActiveX对象的方式以及纯JavaScript的方式。 #### 方法一:使用ActiveX对象(仅适用于IE浏览器) 此方法基于Internet Explorer提供的ActiveX...
3. **使用 ActiveXObject**:由于导出操作需要与Excel应用程序交互,因此需要使用 `ActiveXObject` 对象(仅限 IE 浏览器)来实现。 4. **数据转换与填充**:遍历 Grid 中的数据,并将其转换为 Excel 所需的格式。 5...
本篇文章将详细介绍如何使用 JavaScript 来实现 Excel 文件的导入与导出功能。 #### 一、JavaScript 导出 Excel 导出 Excel 功能主要涉及到使用 ActiveXObject 对象来创建一个 Excel 应用程序实例,并通过该实例来...