vue导出当前页面为pdf,然后保存到后端

vue导出当前页面为pdf,然后保存到后端

前端

  1. 安装html2canvas和jspdf依赖
	npm install html2canvas --save
	npm install jspdf --save  
(如果jspdf 报错,则在index.js中引入
<scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.3.2/jspdf.debug.js"></script>
  1. 在utils中创建htmlToPdf.js文件,并复制以下代码
	// 导出页面为PDF格式
import html2Canvas from 'html2canvas'
//import JsPDF from 'jspdf'
export default{
  install (Vue, options) {
    Vue.prototype.getPdf = function () {
      var title = "测评报告"; //pdf名称
      html2Canvas(document.querySelector('#pdfDom'), {
        allowTaint: true
      }).then(function (canvas) {
        let contentWidth = canvas.width
        let contentHeight = canvas.height
        let pageHeight = contentWidth / 592.28 * 841.89
        let leftHeight = contentHeight
        let position = 0
        //在画布中呈现大小,可调
        let imgWidth = 595.28    //575.28
        let imgHeight = 592.28 / contentWidth * contentHeight //582.28
        let pageData = canvas.toDataURL('image/jpeg', 1.0)
        let PDF = new jsPDF('', 'pt', 'a4')   //jsPDF要小写,因为是cdn引入,可以打开链接看源码
        if (leftHeight < pageHeight) {
         //(pageData, 'JPEG', 左边距 ,上边距,宽,高)
          PDF.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight) //10 20
        } else {
          while (leftHeight > 0) {
            PDF.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight) //10
            leftHeight -= pageHeight
            position -= 841.89
            if (leftHeight > 0) {
              PDF.addPage()
            }
          }
        }
        PDF.save(title + '.pdf')
      }
      )
    }
  }
}
  1. main.js中引入上面那个htmlToPdf文件
import htmlToPdf from '@/components/Utils/htmlToPdf'
Vue.use(htmlToPdf)
  1. 在vue页面中调用
	 <div id="pdfDom">
 	//这里是要导出的html内容
    <el-button @click="getPdf()">保存为PDF</el-button>
 </div>
  1. 后端
 @PostMapping("test")
    @ApiOperation("测试")
    public R test(@RequestParam("file") MultipartFile file){
		System.out.println(file);
		String fileName = file.getOriginalFilename();
		if(fileName.indexOf("\\") != -1){
			fileName = fileName.substring(fileName.lastIndexOf("\\"));
		}
		String filePath = "src/main/resources/static/files/";
		File targetFile = new File(filePath);
		if(!targetFile.exists()){
			targetFile.mkdirs();
		}
		FileOutputStream out = null;
		try {
			out = new FileOutputStream(filePath+fileName);
			out.write(file.getBytes());
			out.flush();
			out.close();
		} catch (Exception e) {
			e.printStackTrace();
			return R.error();
		}
		return R.ok();
 
 
	}

注意:如果要导出的文件内容超出了当前页面,会导致导出的内容不全。需要在htmlToPdf中加入两句话: height: document.getElementById('pdfDom').scrollHeight, windowHeight: document.getElementById('pdfDom').scrollHeight
修改后的文件:

// 导出页面为PDF格式
import html2Canvas from 'html2canvas'
import JsPDF from 'jspdf'
export default{
  install (Vue, options) {
    Vue.prototype.getPdf = function () {
      var title = this.htmlTitle
      html2Canvas(document.querySelector('#pdfDom'), {
        allowTaint: true,
        taintTest: false,
        useCORS: true,
        dpi: window.devicePixelRatio * 6, //将分辨率提高到特定的DPI 提高四倍
        scale: 6, //按比例增加分辨率
        height: document.getElementById('pdfDom').scrollHeight,
        windowHeight: document.getElementById('pdfDom').scrollHeight
      }).then(function (canvas) {
        let contentWidth = canvas.width
        let contentHeight = canvas.height
        let pageHeight = contentWidth / 592.28 * 841.89
        let leftHeight = contentHeight
        let position = 0
        let imgWidth = 595.28
        let imgHeight = 592.28 / contentWidth * contentHeight
        let pageData = canvas.toDataURL('image/jpeg', 1.0)
        let PDF = new JsPDF('', 'pt', 'a4')
        if (leftHeight < pageHeight) {
          PDF.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight)
        } else {
          while (leftHeight > 0) {
            PDF.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight)
            leftHeight -= pageHeight
            position -= 841.89
            if (leftHeight > 0) {
              PDF.addPage()
            }
          }
        }
        PDF.save(title + '.pdf')
      }
      )
    }
  }
}

参考链接:https://blog.csdn.net/qq_36802726/article/details/110624402

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
实现页面转换成 PDF导出的最好方案,主要有两种方法:前端实现和后端实现。 前端实现: 在前端实现页面转换成 PDF导出,可以使用 jsPDF 和 html2canvas 库。jsPDF 是一个用于生成 PDF 文件的 JavaScript 库,而 html2canvas 是一个用于将 HTML 元素转换为 Canvas 的 JavaScript 库。 以下是一个简单的例子,展示如何在 Vue 中使用 jsPDF 和 html2canvas 实现页面转换成 PDF导出: 1. 安装 jsPDF 和 html2canvas 库: ```bash npm install jspdf html2canvas --save ``` 2. 在 Vue 组件中引入 jsPDF 和 html2canvas 库: ```javascript import jsPDF from 'jspdf' import html2canvas from 'html2canvas' ``` 3. 在 Vue 组件中定义导出 PDF 的方法: ```javascript export default { methods: { exportPDF() { // 获取需要导出的元素 let element = document.getElementById('pdf-content') // 将元素转换为 Canvas html2canvas(element).then(canvas => { // 获取 Canvas 图片数据 let imgData = canvas.toDataURL('image/png') // 计算 PDF 页面大小 let pageWidth = 210 let pageHeight = canvas.height * pageWidth / canvas.width // 创建 PDF 对象 let pdf = new jsPDF('p', 'mm', 'a4') // 添加 PDF 页面 pdf.addImage(imgData, 'PNG', 0, 0, pageWidth, pageHeight) // 导出 PDF 文件 pdf.save('export.pdf') }) } } } ``` 在以上代码中,`exportPDF` 方法用于导出 PDF 文件。首先,通过 `document.getElementById` 获取需要导出的元素,这里假设元素的 ID 为 `pdf-content`。然后,使用 `html2canvas` 将元素转换为 Canvas,再通过 Canvas 的 `toDataURL` 方法获取图片数据。接着,计算 PDF 页面大小,创建 jsPDF 对象,并将图片添加到 PDF 中。最后,使用 `pdf.save` 方法导出 PDF 文件。 后端实现: 在后端实现页面转换成 PDF导出,可以使用一些开源的 PDF 库,比如 wkhtmltopdf、WeasyPrint、PDFKit 等。 其中,wkhtmltopdf 是一个开源的 HTML 到 PDF 转换器,可以在 Linux、Windows 和 macOS 等操作系统上使用。WeasyPrint 是一个开源的 HTML 和 CSS 到 PDF 转换器,支持 Linux、macOS 和 Windows 等操作系统。PDFKit 是一个 Node.js 库,可以用于生成 PDF 文件。 以下是一个简单的例子,展示如何在 Vue 中使用 wkhtmltopdf 实现页面转换成 PDF导出: 1. 安装 wkhtmltopdf: ```bash sudo apt-get install wkhtmltopdf ``` 2. 在 Vue 组件中定义导出 PDF 的方法: ```javascript export default { methods: { exportPDF() { // 计算 PDF 文件名 let filename = 'export.pdf' // 获取当前页面 URL let url = window.location.href // 发送 GET 请求,生成 PDF 文件 axios.get(`/api/pdf?url=${encodeURIComponent(url)}&filename=${encodeURIComponent(filename)}`, { responseType: 'blob' }).then(response => { // 创建 blob 对象 let blob = new Blob([response.data], { type: 'application/pdf' }) // 创建下载链接 let link = document.createElement('a') link.href = URL.createObjectURL(blob) link.download = filename // 触发下载 link.click() }) } } } ``` 在以上代码中,`exportPDF` 方法用于导出 PDF 文件。首先,计算 PDF 文件名,这里假设文件名为 `export.pdf`。然后,获取当前页面 URL,将 URL 和文件名作为参数,发送 GET 请求到后端 API,生成 PDF 文件。最后,将返回的二进制数据转换为 blob 对象,创建下载链接,并触发下载。 你可以根据需要选择前端实现或后端实现,以满足你的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值