自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

我們一起探索前端生成PDF

開發(fā) 前端
pdfmake默認(rèn)不支持中文,需要我們自己實(shí)現(xiàn)。找中文的字體文件(ttf結(jié)尾的文件)這個(gè)任務(wù)就交到我們自己手里了,并且字體文件需要支持粗體和斜體,否則字體加粗和斜體屬性不生效。

 巧用pdfmake。

[[400144]]

在使用層面講如何使用pdfmake生成現(xiàn)有報(bào)告,從以下幾方面實(shí)現(xiàn):

  • 支持中文
  • 預(yù)覽頁面搭建
  • 封面實(shí)現(xiàn)和斷頁
  • 頁眉和頁腳實(shí)現(xiàn)
  • pdfmake顯示類型
  • 如何實(shí)現(xiàn)內(nèi)邊距
  • table無法居中顯示

支持中文

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

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

  1. npm run build:vfs 

它會(huì)把你放入examples下的所有字體都統(tǒng)一打包到build文件下的vfs_fonts.js中,然后在項(xiàng)目中使用:

  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.     }  

使用時(shí):

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

預(yù)覽頁面搭建

pdf預(yù)覽的邏輯大都是通過iframe實(shí)現(xiàn),通過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.     }} 

封面實(shí)現(xiàn)和斷頁

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

  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: ["驚天碼盜"

這個(gè)自動(dòng)斷頁可以說是非常的贊,省去了你復(fù)雜的計(jì)算。如果你想某一頁單獨(dú)放一段文案,或者在某段文案后單獨(dú)開一頁,pageBreak可以幫你實(shí)現(xiàn)。

  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.   ] 

頁眉和頁腳

頁眉和頁腳的實(shí)現(xiàn)就太方便了。

  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. }; 

可以精準(zhǔn)定位某個(gè)頁面做一些特殊的設(shè)置。

顯示類型

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

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

內(nèi)邊距的實(shí)現(xiàn)

text文本在pdfmake中是一個(gè)塊級(jí)元素(css思路定義)。無法實(shí)現(xiàn)內(nèi)邊距,單個(gè)text文本獨(dú)占一行。

  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可以實(shí)現(xiàn)內(nèi)邊距,那么我們就可以嘗試以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可以實(shí)現(xiàn)任何樣本組合,但是在單元格垂直居中這塊,卡住了。

  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.   } 

其他

目前發(fā)現(xiàn)不完美的一點(diǎn),就是table單元格垂直居中,除了這一點(diǎn),table很靈活,可以實(shí)現(xiàn)多級(jí)表頭,嵌套表格,合并單元格,靈活定制各個(gè)單元格邊框線條寬度和顏色。

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

本文轉(zhuǎn)載自微信公眾號(hào)「驚天碼盜」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系驚天碼盜公眾號(hào)。

 

責(zé)任編輯:武曉燕 來源: 驚天碼盜
相關(guān)推薦

2024-06-07 14:54:55

2022-02-02 21:17:19

Eslint字段配置

2023-11-03 12:54:00

KAFKA探索中間件

2023-11-29 09:04:00

前端接口

2025-03-13 05:00:00

2023-08-04 08:20:56

DockerfileDocker工具

2021-01-12 05:08:49

DHCP協(xié)議模型

2021-08-27 07:06:09

DubboDocker技術(shù)

2022-03-31 18:59:43

數(shù)據(jù)庫InnoDBMySQL

2022-05-24 08:21:16

數(shù)據(jù)安全API

2023-08-10 08:28:46

網(wǎng)絡(luò)編程通信

2022-10-18 07:33:57

Maven構(gòu)建工具

2023-09-10 21:42:31

2023-06-30 08:18:51

敏捷開發(fā)模式

2021-08-27 07:06:10

IOJava抽象

2024-02-20 21:34:16

循環(huán)GolangGo

2022-01-17 06:59:40

Grep指令linux

2021-12-29 08:27:05

ByteBuffer磁盤服務(wù)器

2022-03-08 17:52:58

TCP格式IP

2021-07-28 07:53:20

Github ActiDotnet 應(yīng)用
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)