日期:2014-05-17 浏览次数:20857 次
上一篇我们讲了怎样把Extjs htmleditor的内容保存成Word,这一篇,我们主要讲怎样在客服端(浏览器端)保存htmleditor里的内容成word。
首先介绍两个Javascript框架:
1、 downloadify
这是一个非常小的Javascript+Flash库,它允许用户在浏览器端保存内容到用户的PC,不需要和服务器交互。
项目Demo:http://pixelgraphics.us/downloadify/test.html
项目主页: https://github.com/dcneiner/Downloadify
2、opensave
opensave 是一个小巧的Javascript和ActionScript(SWF)的文件打开和文件保存的库,它可以open用户本地文件在浏览器里显示,同时也可以save浏览器里的页面到用户的电脑里。
项目主页: http://www.gieson.com/Library/projects/utilities/opensave/
downloadify 仅提供了下载功能,opensave提供了open 本地文件功能,同时也能定制button的text,功能更加强大。
由于downloadify小巧,我们的另外一个扩展库(Extjs Gridpanel 导出成excel)也使用到了downloadify,所以决定使用downloadify。
页面里没用使用Extjs的话,可以参考他们的demo很容易实现导出,下面我们主要讲解在Extjs里加入downloadify导出word。
废话少说,直接贴代码:
jsp 文件:
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Insert title here</title> <link rel="stylesheet" type="text/css" href="<%=request.getContextPath()%>/extjs/resources/css/ext-all.css" /> <link rel="stylesheet" type="text/css" href="<%=request.getContextPath()%>/css/Extmain.css" /> <script type="text/javascript" src="<%=request.getContextPath()%>/extjs/ext-all.js"></script> <script type="text/javascript" src="<%=request.getContextPath()%>/extjs/exporter/downloadify.min.js"></script> <script type="text/javascript" src="<%=request.getContextPath()%>/extjs/exporter/swfobject.js"></script> <script type="text/javascript" src="<%=request.getContextPath()%>/js/constant.js"></script> <script type="text/javascript" src="<%=request.getContextPath()%>/view/project/audit/audit_scheme_view.js"></script> </head> <body style="margin:0; padding:0;"> <script type="text/javascript"> Ext.onReady(function(){ createPanel(); loadScheme('${projectId}'); }); </script> </body> </html>
/** * 创建显示面板 */ function createPanel(){ new Ext.panel.Panel({ title: '查看工作方案', id: 'contentPanel', renderTo: Ext.getBody(), width : document.body.clientWidth*0.98, height: document.documentElement.clientHeight, titleAlign :'center', frame: true, layout: 'fit', items: [{ xtype: 'htmleditor', id: 'content', name: 'content', overflowY: 'scroll', enableColors: false, enableAlignments: false, enableFont: false, enableFontSize: false, enableFormat: false, enableLinks: false, enableLists: false, enableSourceEdit: false }], tbar: ['->',{ xtype: 'button', text: '导出', iconCls: 'icon-export-word', width: 58, height: 28, listeners:{ afterrender: setExportButton } }] }); } /** * 设置导出word的按钮。 * @param button * @param eOpts */ function setExportButton(button){ Downloadify.create(button.getId(), { filename: function(){ return "审计工作方案.doc"; }, data: function(){ var headerStart = "<html xmlns:v='urn:schemas-microsoft-com:vml' " + "xmlns:o='urn:schemas-microsoft-com:office:office'&qu