js生成word中图片处理方法
更新时间:2018年01月06日 09:09:44 作者:pdandan
下面小编就为大家分享一篇js生成word中图片处理方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
首先功能是要求前台导出word,但是前后台是分离的,图片存在后台,所以就存在跨域问题。
导出文字都是没有问题的(jquery.wordexport.js),但是导出图片就存在问题了:
图片是以链接形式存到word中,这样如果是需要vpn的网站就会存在生成的word在没有vpn的情况下打不开,有vpn的情况下必须启用编辑才能加载出来图片。
解决办法:将图片转换成Data URL格式,再导出。
详细代码如下所示:
function changeImgToDataurl(){ var charImg = document.all("exportdom").getElementsByTagName("img"); var imgURLs = ""; for (var i = 0; i < charImg.length; i++) { var imgURL = charImg[i].currentSrc; getBase64(imgURL,charImg[i]); } } function getBase64(url,charImg){ var Img = new Image(); Img.crossOrigin = "Anonymous";//跨域必须使用,且后台也得设置允许跨域 dataURL=''; Img.src=url; Img.onload=function(){ //要先确保图片完整获取到,这是个异步事件 var canvas = document.createElement("canvas"), //创建canvas元素 width=Img.width, //确保canvas的尺寸和图片一样 height=Img.height; canvas.width=width; canvas.height=height; canvas.getContext("2d").drawImage(Img,0,0,width,height); //将图片绘制到canvas中 dataURL=canvas.toDataURL('image/jpg'); //转换图片为dataURL condataurl?condataurl(dataURL,charImg):null; //调用回调函数 }; } function condataurl(dataURL,charImg){ charImg.src=dataURL; //console.log(charImg); }
以上这篇js生成word中图片处理方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
JavaScript定时器setTimeout、setInterval使用详解
网站开发过程中经常会用到各种各样的定时任务,这时我们会用到setTimeout和setInterval方法,下面这篇文章主要给大家介绍了关于JavaScript定时器setTimeout、setInterval使用的相关资料,需要的朋友可以参考下2023-04-04JavaScript中判断变量是数组、函数或是对象类型的方法
这篇文章主要介绍了JavaScript中判断变量是数组、函数或是对象类型的方法,需要的朋友可以参考下2015-02-02firefox firebug中文入门教程 脚本之家新年特别版
最近看了一篇文章感触颇深,对于firebug作为脚本之家的编辑经常看的到,但可悲的是没怎么用过,不是不用那个而是不会用,刚好看了一篇基础的文章特别整理下。2010-01-01
最新评论