需要用到的插件包
html2canvas
file-saver
jszip
首先时使用html2canvas将dom转成图片,这里的图片格式为base64/png
const base64List=[];
_this.$nextTick(() => {
const imgNodes=document.getElementsByName("imgNode")
for(let node of imgNodes)
{
html2canvas(node,{
backgroundColor: null//无背景,即透明背景图
}).then(resolve => {
let imgUrl = resolve.toDataURL('image/png');
//去除data:image/png;base64,
base64List.push(imgUrl.substring(22))
})
}
})
在使用jszip将base64/png放入zip压缩包,最后使用file-saver 的 saveAs将压缩包下载
下面逻辑需要延迟执行否则可能图片还未生成 可使用setInterval ,校验dom的lenth 和base64List的lenth是否相等后再执行
let blogTitle="图片"
let zip = new JSZip()
let imgs = zip.folder(blogTitle)
for (let i = 0; i < base64List.length; i++) {
imgs.file('photo' + i + '.png', base64List[i], {base64: true})
}
zip.generateAsync({type: 'blob'}).then(function (content) {
saveAs(content, blogTitle + '.zip')
})
备注:
1,html2canvas是将dom转成图片,即相当于在网页上截图。所以使用时需确认dom已生成,(通常可通过调整z-index等方式来隐藏该dom)
2.把图片的base64编码添加进压缩包前必须先剔除前面的"data:image/png;base64," ,去除后再调用jsZip的file方法添加进压缩包,在添加的时候声明base64:true
比如base64编码:""