最近有需求将数据导出到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(对象的列表集合)为一组 组织好页面上 再得到这些数据后进行替换。

数据组织形式如下:

../zwgl/zw008-ZwMkjbxxCTRL-showWxytp.png?xh=3041

使用:

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();

}

注意:

替换图片的值需要解释一下:

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代码:

/**

*

Title: 用word书签替换的方式将内容导出到word

*

Description: **

*

Copyright: Copyright (c) 2007-2010

*

Company: **

* @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

for(var j=0; 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

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

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

var vo = {};

for(var j=0;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

var vo = {};

for(var j=0;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

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]+"/";

}

先说到这里吧,以后有更好的再更新,希望对大家有用。

js实现word生成书签_javascript下用ActiveXObject控件替换word书签,将内容导出到word后打印...相关推荐

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

    javascript下用ActiveXObject控件替换word书签,将内容导出到word后打印第2/2页 更新时间:2008年06月21日 22:57:31   作者: 由于时间比较紧,没多的时候 ...

  2. DevExpress的下拉框控件LookUpEdit的使用、添加item选项值、修改默认显示值

    场景 Winform控件-DevExpress18下载安装注册以及在VS中使用: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/1 ...

  3. JavaScript--在页面的下拉框控件中遍历出日期--先天下能力工场

    在单独的javascript文件中建立如下代码,然后在jsp或者html页面中引用该文件,即可实现自动遍历生成option下拉框控件 function pageInit() { makeYear(); ...

  4. .NET下的验证码控件John.Controls.ValidateCode2V for .NET beta1

    预告下一个作品是选项卡John.Controls.TabularMultiView for .NET(难产ing,由于最近要处理的事情很多,身体上也有点不支,发布时间推迟) 注册了帐号好几久,都没发过 ...

  5. extjs 月份选择控件_Ext JS 4实现带week(星期)的日期选择控件(实战二)

    前言 JavaScript 中的日期和时间 Ext JS 4实现带week(星期)的日期选择控件(实战一) 如对本篇的一些预备知识需详尽了解,可参考以上两篇. Javascript 有提供Date 对 ...

  6. 打开word文档总是自动弹出控件工具条的解决办法:

    打开word文档总是自动弹出控件工具条的解决办法: 1.查看是否word文档和模板中了'apmp宏病毒,按ALT+F11组合键,双击当前文档下属的ThisDocument,清空里面的内容:双击Norm ...

  7. android google 下拉刷新 csdn,android SwipeRefreshLayout google官方下拉刷新控件

    下拉刷新功能之前一直使用的是XlistView很方便我前面的博客有介绍 SwipeRefreshLayout是google官方推出的下拉刷新控件使用方法也比较简单 今天就来使用下SwipeRefres ...

  8. Android SwipeRefreshLayout 官方下拉刷新控件介绍

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24521483 下面App基本都有下拉刷新的功能,以前基本都使用XListView ...

  9. android 下拉刷新 组件,android系统自带下拉刷新控件的实现

    android系统自带的下拉刷新控件SwipeRefreshLayout位于android.support.v4.widget包下,实现步骤如下: 1.在布局文件中添加该控件,该控件一般作为父控件,而 ...

  10. 用友二次开发 用友控件 Js宿主脚本 调用用友T6 登录 参照 控件示例

    用友二次开发 用友控件 Js宿主脚本 调用用友T6 登录 参照 控件示例 /*****************************************, code by 张朋 ' Email: ...

最新文章

  1. LeetCode 255. 验证前序遍历序列二叉搜索树(单调栈)*
  2. 有趣 IOS 开展 - block 使用具体解释
  3. 中科大「少年班」对手来了!清华「丘成桐领军计划」招收优秀中学生
  4. Linux 命令(28)—— tee 命令
  5. Zemax操作--9(全局坐标设定及使用方法)
  6. 新零售智慧供应链架构
  7. (2)VBA 关键字
  8. 使用MDK创建stm32 库函数工程简单教程
  9. c语言:模拟用户密码登录
  10. python蜂鸣器音乐代码_6.蜂鸣器唱歌
  11. Java 23种设计模式系列之观察者模式(常用)
  12. 10亿级存储挑战!看一看、微信广告、微信支付、小程序都在用的存储系统究竟是怎么扛住的?!
  13. 4.FTP服务配置与原理
  14. linux 解压zip大文件(解决乱码问题)
  15. 【能源管理】制造行业中汽车厂房综合能效管理平台应用分析
  16. Automa自动化爬取文本(一)
  17. java计算机毕业设计VUE教育网站设计与实现源码+mysql数据库+系统+lw文档+部署
  18. ZIZI - A3 再自己的“库”中增加体现丰富意象的“线条”
  19. DSP音频算法软件开发开发架构
  20. 通常 在微型计算机中3.0ghz所指的是,太原理工大学测验《大学计算机基础》A考题.doc...

热门文章

  1. 如果有人问你爬虫抓取技术的门道,请叫他来看这篇文章
  2. 服务器系统在虚拟机安装win7系统安装教程,vmware虚拟机如何安装win7系统_vmware虚拟机安装win7纯净版图文教程...
  3. 移动端天气系统--【下雨】效果之【雷电】的实现和分析
  4. 大数据分析-实验五 pdfminer
  5. 如何同时对多个 Word 文档批量插入页眉页脚、修改页眉页脚以及添加页码
  6. while 循环语句的使用
  7. 使用matlab进行简单图像处理
  8. Git下载安装(官网) 拉取代码的两种方法
  9. 微信小程序——视图层
  10. 古风诗词选别名-欢迎留言