成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

我們一起探索前端生成PDF

開發 前端
pdfmake默認不支持中文,需要我們自己實現。找中文的字體文件(ttf結尾的文件)這個任務就交到我們自己手里了,并且字體文件需要支持粗體和斜體,否則字體加粗和斜體屬性不生效。

 巧用pdfmake。

[[400144]]

在使用層面講如何使用pdfmake生成現有報告,從以下幾方面實現:

  • 支持中文
  • 預覽頁面搭建
  • 封面實現和斷頁
  • 頁眉和頁腳實現
  • pdfmake顯示類型
  • 如何實現內邊距
  • table無法居中顯示

支持中文

pdfmake默認不支持中文,需要我們自己實現。找中文的字體文件(ttf結尾的文件)這個任務就交到我們自己手里了,并且字體文件需要支持粗體和斜體,否則字體加粗和斜體屬性不生效。

把我們找到的字體文件,放入pdfmake官方github目錄下examples下,執行

  1. npm run build:vfs 

它會把你放入examples下的所有字體都統一打包到build文件下的vfs_fonts.js中,然后在項目中使用:

  1. import pdfmake from "pdfmake/build/pdfmake" 
  2. const pdfFonts = require('@/assets/js/vfs_fonts.js')  
  3. pdfMake.vfs = pdfFonts  
  4. pdfMake.fonts = {  
  5.     Roboto: {  
  6.         normal: 'Roboto-Regular.ttf',  
  7.         bold: 'Roboto-Medium.ttf',  
  8.         italics: 'Roboto-Italic.ttf',  
  9.         bolditalics: 'Roboto-Italic.ttf'  
  10.     },  
  11.     微軟雅黑: {  
  12.         normal: '微軟雅黑.ttf',  
  13.         bold: '微軟雅黑-bold.ttf',  
  14.         italics: '微軟雅黑-italics.ttf',  
  15.         bolditalics: '微軟雅黑-bolditalics.ttf'  
  16.     }  

使用時:

  1. var docDefinition = {  
  2.     content: [ '驚天碼盜' ],  
  3.     defaultStyle: {  
  4.         fontSize: 15,  
  5.         bold: true
  6.         font:"微軟雅黑" 
  7.     }  
  8. }; 

預覽頁面搭建

pdf預覽的邏輯大都是通過iframe實現,通過getDataUrl獲取url地址

  1. import pdfmake from "pdfmake/build/pdfmake" 
  2. export function previewPdf(params) { 
  3.     if(!params) return ; 
  4.     const pdfDocGenerator = pdfMake.createPdf(params);    
  5.     pdfDocGenerator.getDataUrl( dataUrl=>{ 
  6.         const targetElement = document.querySelector("#iframeContainer"); 
  7.         const pdfMakeIframe = document.querySelector("#pdfMakeKey"); 
  8.         if(pdfMakeIframe){ 
  9.             pdfMakeIframe.src = dataUrl; 
  10.         }else
  11.             const iframe = document.createElement("iframe"); 
  12.             iframe.id = 'pdfMakeKey'
  13.             iframe.src = dataUrl;  
  14.             targetElement.appendChild(iframe) 
  15.         } 
  16.     }} 

封面實現和斷頁

pdfmake默認是沒有封面這個設置,但是提供了一個設置背景的函數,可以給每個頁面設置一個背景,可以是文字背景,也可以是圖片背景。

  1. const docDefinition = { 
  2.     background: function( currentPage, pageSize){ 
  3.         if(currentPage === 1){ 
  4.             return { 
  5.                 iamge: "bgCoverImgUrl"
  6.                 width: pageSize.width, 
  7.                 height: pageSize.height 
  8.             } 
  9.         } 
  10.         return null
  11.     } 
  12.     content: ["驚天碼盜"

這個自動斷頁可以說是非常的贊,省去了你復雜的計算。如果你想某一頁單獨放一段文案,或者在某段文案后單獨開一頁,pageBreak可以幫你實現。

  1.   pageOrientation: 'portrait'
  2.   content: [ 
  3.     {text: 'Text on Portrait'}, 
  4.     {text: 'Text on Landscape', pageOrientation: 'landscape', pageBreak: 'before'}, 
  5.     {text: 'Text on Landscape 2', pageOrientation: 'portrait', pageBreak: 'after'}, 
  6.     {text: 'Text on Portrait 2'}, 
  7.   ] 

頁眉和頁腳

頁眉和頁腳的實現就太方便了。

  1. const docDefinition = { 
  2.   footer: function(currentPage, pageCount) {  
  3.         return currentPage.toString() + ' of ' + pageCount;  
  4.   }, 
  5.   header: function(currentPage, pageCount, pageSize) { 
  6.     return [{ 
  7.         columns: [ 
  8.             { 
  9.                 text:  this.headerContent.left
  10.                 alignment:  'left' 
  11.             }, 
  12.             { 
  13.                 text:  this.headerContent.middle, 
  14.                 alignment:  'center' 
  15.             }, 
  16.             { 
  17.                 text:  this.headerContent.right
  18.                 alignment:  'right' 
  19.             } 
  20.             ], 
  21.  
  22.             margin: [10, 20] 
  23.         }] 
  24.   }, 
  25.   content: ["驚天碼盜"
  26. }; 

可以精準定位某個頁面做一些特殊的設置。

顯示類型

相對于前端來說大多顯示類型都已經定型了,比如表格、文本、列表、圖片等。在pdfmake中一共給我們提供了這些顯示類型:

text
普通文本,需要注意的就是字體,如果所提供字體不支持,所設置的屬性就不顯示。同時text可以嵌套。
columns
列,平鋪的列元素。在pdfmake中沒有塊級元素的概念,如果你想平鋪兩個或者多個文本(比如前面icon,后面文本),colums會滿足你。每列之間的距離可以通過columnGap設置。
list
跟html標簽ul或ol相同。
table
表格,唯一提供內邊距屬性的類型。強大到可以實現任何簡單的樣式,相當于display:table。但是弊端也相當明顯,不能垂直居中。
image/svg
圖片。
stack 棧,相當于數組[]。

內邊距的實現

text文本在pdfmake中是一個塊級元素(css思路定義)。無法實現內邊距,單個text文本獨占一行。

  1. const dd = { 
  2.     content: [ 
  3.         'First paragraph'
  4.         { text:"234", background:'red',color:"#fff",fontSize:20 }, 
  5.         'Another paragraph, this time a little bit longer to make sure, this line will be divided into at least two lines' 
  6.     ] 

在pdfmake類型中只有table可以實現內邊距,那么我們就可以嘗試以table的方式布局,例如

  1. const dd = { 
  2.   content: [ 
  3.     { 
  4.       margin: [0, 20], 
  5.       table: { 
  6.         body: [ 
  7.           [ 
  8.             { text: 'CONTENTS', width: 'auto', fillColor: '#e7e6e6', fontSize: 26 }, 
  9.             { text: 'Padding ', fillColor: '#58ac5b', color: '#FFF', fontSize: 26 } 
  10.           ] 
  11.         ] 
  12.       }, 
  13.       layout: { 
  14.         defaultBorder: false
  15.         paddingLeft: function (i, node) { 
  16.           if (i === 0) { 
  17.             return 10 
  18.           } 
  19.           return 20 
  20.         }, 
  21.         paddingRight: function (i, node) { 
  22.           if (i === 0) { 
  23.             return 10 
  24.           } 
  25.           return 20 
  26.         }, 
  27.         paddingTop: function (i, node) { return 10 }, 
  28.         paddingBottom: function (i, node) { return 10 } 
  29.       } 
  30.     } 
  31.   ] 

效果是:

像目錄這種效果也是table做出來的:

table的缺陷

看似table可以實現任何樣本組合,但是在單元格垂直居中這塊,卡住了。

  1.   // style: 'tableExample'
  2.   table: { 
  3.     body: [ 
  4.       ['Column 1''Column 2The following table has nothing more than a body array,The following table has nothing more than a body array,The following table has nothing more than a body array,The following table has nothing more than a body array''Column 3'], 
  5.       ['One value goes here''Another one here''OK?'
  6.     ] 
  7.   } 

其他

目前發現不完美的一點,就是table單元格垂直居中,除了這一點,table很靈活,可以實現多級表頭,嵌套表格,合并單元格,靈活定制各個單元格邊框線條寬度和顏色。

同時還具備水印、加密、二維碼生成、內外鏈接、目錄生成。相比jspdf幫我們節省了很多步驟。那么我們下期聊聊jsPdf。

本文轉載自微信公眾號「驚天碼盜」,可以通過以下二維碼關注。轉載本文請聯系驚天碼盜公眾號。

 

責任編輯:武曉燕 來源: 驚天碼盜
相關推薦

2022-02-02 21:17:19

Eslint字段配置

2024-06-07 14:54:55

2023-11-03 12:54:00

KAFKA探索中間件

2023-11-29 09:04:00

前端接口

2025-03-13 05:00:00

2022-03-31 18:59:43

數據庫InnoDBMySQL

2023-08-10 08:28:46

網絡編程通信

2021-08-27 07:06:09

DubboDocker技術

2021-01-12 05:08:49

DHCP協議模型

2022-10-18 07:33:57

Maven構建工具

2023-08-04 08:20:56

DockerfileDocker工具

2023-06-30 08:18:51

敏捷開發模式

2022-05-24 08:21:16

數據安全API

2023-09-10 21:42:31

2024-02-20 21:34:16

循環GolangGo

2021-07-28 07:53:20

Github ActiDotnet 應用

2022-01-17 06:59:40

Grep指令linux

2021-08-27 07:06:10

IOJava抽象

2021-12-29 08:27:05

ByteBuffer磁盤服務器

2022-03-08 17:52:58

TCP格式IP
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美一级免费看 | 日韩av一区二区在线观看 | 欧美成人h版在线观看 | 99久久久国产精品 | 亚洲国产精品区 | 日日夜夜天天干 | 国产区在线观看 | 999热精品视频 | 国产一区二区三区在线 | 亚洲国产成人久久久 | 日韩av在线一区 | 中文字幕高清 | 日韩一区在线播放 | 一区二区三区四区在线视频 | 中文字幕一页二页 | 成人片免费看 | 精品久久九九 | 日韩在线精品视频 | 久久99这里只有精品 | 国产精品夜夜夜一区二区三区尤 | 特黄毛片 | 日韩欧美三级 | 在线免费黄色 | 九九热最新地址 | 亚洲成人一区二区三区 | 久久一二| 中文字幕乱码视频32 | 成人精品一区 | 午夜激情在线视频 | 在线午夜| 欧美日韩一区二区三区在线观看 | 欧美在线成人影院 | 欧美精品一区二区三区四区五区 | 性在线| 国产一区二区三区在线免费观看 | 亚洲欧洲在线观看视频 | 久久久国产一区 | 亚洲精品久久 | 欧美日韩在线播放 | 中国美女一级黄色片 | 给我免费的视频在线观看 |