소스 검색

pdf插件调试

九山 3 년 전
부모
커밋
af0e9d7e08

+ 5 - 0
README.md

@@ -26,6 +26,11 @@ this.API.post("login", {
   ....
 });
 ```
+### Get_PDF
+公共的pdf导出工具  
+```  
+this.Get_PDF.downloadPDF(document.querySelector(id), 导出的pdf名称)
+```  
 ### BASE
 ###### numberB0(n)
 为各位数字自动补充一个0,用于日期补零。

+ 3 - 0
package.json

@@ -18,6 +18,7 @@
     "uglifyjs-webpack-plugin": "^2.2.0",
     "vue": "^2.6.11",
     "vue-json-excel": "^0.3.0",
+    "vue-pdf": "^4.2.0",
     "vue-router": "^3.2.0",
     "vuescroll": "^4.17.3",
     "vuex": "^3.4.0"
@@ -28,7 +29,9 @@
     "@vue/cli-plugin-vuex": "~4.5.0",
     "@vue/cli-service": "~4.5.0",
     "babel-plugin-component": "^1.1.1",
+    "html2canvas": "^1.0.0-rc.7",
     "image-webpack-loader": "^7.0.1",
+    "jspdf": "^2.3.1",
     "sass": "^1.26.5",
     "sass-loader": "^8.0.2",
     "vue-template-compiler": "^2.6.11",

+ 11 - 5
src/assets/css/base.scss

@@ -208,11 +208,11 @@ textarea {
   -webkit-appearance: none;
 }
 
-* {
-  -webkit-box-sizing: border-box;
-  -moz-box-sizing: border-box;
-  box-sizing: border-box;
-}
+// * {
+//   -webkit-box-sizing: border-box;
+//   -moz-box-sizing: border-box;
+//   box-sizing: border-box;
+// }
 
 input::-webkit-input-placeholder {
   /* WebKit, Blink, Edge */
@@ -352,3 +352,9 @@ body,
 }
 
 /***框架样式 - 结束***/
+
+
+
+/***ElUI - 公共调整 - 开始***/
+
+/***ElUI - 公共调整 - 结束***/

+ 5 - 6
src/assets/css/healthManagement/healthAssessmentDetailed.scss

@@ -1,7 +1,6 @@
-.box{
-    width: 100%;
-    // display: flex;
-    justify-content: space-around;
-     align-items: center;
-     overflow: hidden;
+.page{
+  .form{
+    position: absolute;
+    right: 40px;
+  }
 }

+ 4 - 0
src/assets/js/healthManagement/healthAssessmentDetailed.js

@@ -72,6 +72,10 @@ export default {
         this.KeyparameterData();
     },
     methods:{
+      // 导出pdf
+      getPdf(name){
+        this.Get_PDF.downloadPDF( document.querySelector('#pdfDom'),name)
+      },
         headStyle() {
           return "text-align:center"
         },

+ 3 - 0
src/main.js

@@ -28,6 +28,9 @@ Vue.prototype.ECLZX = EClzx;
 // import formCheck from "@tools/formCheck"; // 表单的处理
 // Vue.prototype.FC = formCheck;
 
+import Get_PDF from '@tools/htmlToPdf'; // pdf导出
+Vue.prototype.Get_PDF = Get_PDF;
+
 // 滚动条
 import vuescroll from "vuescroll"; 
 Vue.use(vuescroll, {

+ 94 - 32
src/tools/htmlToPdf.js

@@ -1,36 +1,98 @@
-import html2Canvas from 'html2canvas'
-import JsPDF from 'jspdf'
-
-export default{
-  install (Vue, options) {
-    Vue.prototype.getPdf = function (title) {
-      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
-        let imgHeight = 592.28 / contentWidth * contentHeight
-        let pageData = canvas.toDataURL('image/jpeg', 1.0)
-        let PDF = new JsPDF('', 'pt', 'a4')
+import html2canvas from 'html2canvas';
+import JsPDF from 'jspdf';
+
+/**
+ * @param  ele          要生成 pdf 的DOM元素(容器)
+ * @param  padfName     PDF文件生成后的文件名字
+ * */
+
+function downloadPDF(ele, pdfName){
+
+    let eleW = ele.offsetWidth;// 获得该容器的宽
+    let eleH = ele.offsetHeight;// 获得该容器的高
+
+
+    let eleOffsetTop = ele.offsetTop;  // 获得该容器到文档顶部的距离
+    let eleOffsetLeft = ele.offsetLeft; // 获得该容器到文档最左的距离
+
+    var canvas = document.createElement("canvas");
+    var abs = 0;
+
+    let win_in = document.documentElement.clientWidth || document.body.clientWidth; // 获得当前可视窗口的宽度(不包含滚动条)
+    let win_out = window.innerWidth; // 获得当前窗口的宽度(包含滚动条)
+
+    if(win_out>win_in){
+        // abs = (win_o - win_i)/2;    // 获得滚动条长度的一半
+        abs = (win_out - win_in)/2;    // 获得滚动条宽度的一半
+        // console.log(a, '新abs');
+    }
+
+    canvas.width = eleW * 2;    // 将画布宽&&高放大两倍
+    canvas.height = eleH * 2;
+
+
+
+
+    var context = canvas.getContext("2d");
+
+    context.scale(2, 2);
+
+    context.translate(-eleOffsetLeft -abs, -eleOffsetTop);
+    // 这里默认横向没有滚动条的情况,因为offset.left(),有无滚动条的时候存在差值,因此
+    // translate的时候,要把这个差值去掉
+
+    // html2canvas(element).then( (canvas)=>{ //报错
+    // html2canvas(element[0]).then( (canvas)=>{
+    html2canvas( ele, {
+        dpi: 300,
+        // allowTaint: true,  //允许 canvas 污染, allowTaint参数要去掉,否则是无法通过toDataURL导出canvas数据的
+        useCORS:true  //允许canvas画布内 可以跨域请求外部链接图片, 允许跨域请求。
+    } ).then( (canvas)=>{
+
+        var contentWidth = canvas.width;
+        var contentHeight = canvas.height;
+        //一页pdf显示html页面生成的canvas高度;
+        var pageHeight = contentWidth / 592.28 * 841.89;
+        //未生成pdf的html页面高度
+        var leftHeight = contentHeight;
+        //页面偏移
+        var position = 0;
+        //a4纸的尺寸[595.28,841.89],html页面生成的canvas在pdf中图片的宽高
+        var imgWidth = 595.28;
+        var imgHeight = 595.28/contentWidth * contentHeight;
+
+        var pageData = canvas.toDataURL('image/jpeg', 1.0);
+
+
+
+        var pdf = new JsPDF('', 'pt', 'a4');
+
+        //有两个高度需要区分,一个是html页面的实际高度,和生成pdf的页面高度(841.89)
+        //当内容未超过pdf一页显示的范围,无需分页
         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.addImage(pageData, 'JPEG', 左,上,宽度,高度)设置在pdf中显示;
+            pdf.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight);
+            // pdf.addImage(pageData, 'JPEG', 20, 40, 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')
-      }
-      )
-    }
-  }
+
+        //可动态生成
+        pdf.save(pdfName);
+    })
+
+
 }
+
+
+export default {
+    downloadPDF
+}

파일 크기가 너무 크기때문에 변경 상태를 표시하지 않습니다.
+ 559 - 178
src/views/healthManagement/healthAssessmentDetailed.vue


+ 3 - 3
src/views/main.vue

@@ -13,10 +13,10 @@
           <keep-alive> 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们
           当组件在 <keep-alive> 内被切换,它的 activated 和 deactivated 这两个生命周期钩子函数将会被对应执行。
         -->
-        <keep-alive v-if="$route.meta.keepAlive || $route.meta.keepAlive === undefined">
+        <!-- <keep-alive v-if="$route.meta.keepAlive || $route.meta.keepAlive === undefined">
           <router-view></router-view>
-        </keep-alive>
-        <router-view v-else></router-view>
+        </keep-alive> -->
+        <router-view></router-view>
       </VueScroll>
     </div>
   </div>