首页 > 其他分享 >Chrome 103支持使用本地字体,纯前端导出PDF优化

Chrome 103支持使用本地字体,纯前端导出PDF优化

时间:2022-11-26 15:24:07浏览次数:71  
标签:Chrome 字体 服务器 PDF 103 页面

Chrome 103支持使用本地字体,纯前端导出PDF优化

 

在前端导出PDF,解决中文乱码一直是一个头疼的问题。要解决这个问题,需要将ttf等字体文件内容注册到页面PDF生成器中。但是之前网页是没有权限直接获取客户机器字体文件,这时就需要从服务器下载字体文件或者提示用户选择字体文件上传到页面。对于动辄数十兆(M)的中文字体文件,网络不好时并不是一个好的解决方案。

Chrome 103

提高页面性能的一种方法是对当前的使用资源经行提示。例如,预加载文件或连接到不同的服务器。

<link as="font" crossorigin="anonymous"
      href="..." rel="preload">
<link as="font" crossorigin="anonymous"
      href="..." rel="preload">
<link href="https://web-dev.imgix.net"
      rel="preconnect">

但是在服务器发送页面内容之前,浏览器是无法对提示采取行动。

服务器需要几百毫秒才能生成一个请求页面,在浏览器开始接收页面内容之前,服务器是不进行任何处理的。但是在这个等待的过程中,服务器是需要一些固定子资源,例如 CSS 文件、JavaScript 和图像内容,这个时候服务器可以立即响应新的 HTTP 103 Early Hints 状态代码,并询问浏览器预加载那些子资源,以提供高座效率。

一旦服务器生成了页面,它就可以用正常的 HTTP 200 响应发送它。当页面进入时,浏览器已经开始加载所需的资源。作为一个新 HTTP 状态代码,所以它需要更新我们服务器。

本地字体访问

Web 上的字体一直是一个挑战,尤其是允许用户创建自己的图形和设计的应用程序就是一个难点。现在应用程序只能使用网络字体,但无法获得用户在其计算机上安装的字体列表;而且,无法访问完整的字体表数据,如果我们需要实现自己的自定义文本堆栈,就很复杂。

而在新版本中,这个问题得到了很好解决。Chrome 103版本中新的字体API可以让web应用获取到用户在本地电脑上安装的所有字体信息,同时还可以获取到字体内容。

调用window.queryLocalFonts(),会返回用户安装字体的数组。

const pickedFonts = await self.queryLocalFonts();
for (const fontData of pickedFonts) {
  console.log(fontData.postscriptName);
  console.log(fontData.fullName);
  console.log(fontData.family);
  console.log(fontData.style);
}

处于安全性的考虑,获取字体信息需要获取到用户的授权。当第一调用queryLocalFonts时,Chrome会弹出权限申请:

权限同意后,就可以获取所有安装字体的信息

使用navigator.permissions.query可以检查权限

async function requestPremission(){
  const { state } = await navigator.permissions.query({
    name: "local-fonts"
  });
  console.log(state)
  if (state === 'granted') {
    query();
  } else if (state === 'prompt') {
    alert("请授予权限!")
    query();
  }
  else{
    alert("没有权限获取字体")
  }
}

使用本地字体导出PDF

接下来我们介绍如何使用本地字体进行PDF导出。
选择需要使用的字体内容,注册到PDF生成工具中

使用blob 方法可以获取字体文件内容
let currentFont = fontList[fontListSelect.value];
const blob = await currentFont.blob();

使用字体名称注册

//将Blob 对象转换成 ArrayBuffer
var reader = new FileReader();
reader.onload = function (e) {
  var fontrrayBuffer = reader.result;
  var fonts = GC.Spread.Sheets.PDF.PDFFontsManager.getFont(currentFont.family) || {};
  fonts[fontType] = fontrrayBuffer;
  GC.Spread.Sheets.PDF.PDFFontsManager.registerFont(currentFont.family, fonts);
}
reader.readAsArrayBuffer(blob);

接下来导出含有本地字体的PDF:

这里需要注意,使用本地字体风险也是不可避免的,如果用户没有安装对应字体,在网页中浏览器会使用其他字体进行渲染,倒是PDF依旧会有出现乱码的风险。解决方法是需要从服务器中下载目标字体或使用其他字体作为替代。

标签:Chrome,字体,服务器,PDF,103,页面
From: https://www.cnblogs.com/sexintercourse/p/16927466.html

相关文章

  • itextsharp.dll(4.0.8.0)完整示例PDF
    itextsharp.dll(4.0.8.0)完整示例PDF privatevoidbutton1_Click(objectsender,EventArgse)       {           //Document:(文档)生成p......
  • Python给PDF文件打水印
    坑啊.....PHP实现不了才出此下策:首先声明使用Python2.7版本!!! Python2.7版本! Python2.7版本! Python2.7版本!重要的事情说三遍!说三遍!说三遍!安装包:pip2installp......
  • how to run XPath in Chrome console All In One
    howtorunXPathinChromeconsoleAllInOnesolutions$x()function$x;//ƒ$x(){[nativecode]}$x(`/html/head/meta`);//(28) [meta,meta,meta,me......
  • 使用html2canvas和jspdf将页面保存位pdf
    使用html2canvas和jspdf将页面保存位pdf<scriptsrc="https://unpkg.com/jspdf@latest/dist/jspdf.umd.min.js"></script><scriptsrc="https://unpkg.com/html2canvas@......
  • PDF科普:什么是PDF,PDF有什么好处
    什么是PDF文件可移植文档格式(PDF),是Adobe于1992年开发的一种文件格式,以一种与应用软件、硬件和操作系统无关的方式显示文档,包括文本格式和图像。基于PostScript语言,每个......
  • WatchPdf
    WatchPdfiframe+pdfsrc//MOCKpdfconst[pdfUrl,setPdfUrl]=useState();const[iframeVisible,setIframeVisible]=useState(false);const[loading,setLoadi......
  • Java 8 itextpdf 实现 给 pdf 添加水印
    前言给pdf添加水印功能是日常开发中经常会遇到的问题,下面我们就来看看怎么通过Java实现给pdf文件添加水印环境新创建个SpringBoot的项目,然后添加itextpdf的依赖,具体的pom.x......
  • mysql打开表报错err 1030 - got error 1877 'Unknown error 1877' from storage engin
    参考解决链接https://www.cnblogs.com/caijh/p/7244915.html查看日志文件位置showvariableslike'%error%';根据错误日志分析,删除log_file文件cd/server/my......
  • 安装Axure RP Extension for Chrome插件的简单方法
    只需三步,不用下载AxureRPExtensionforChrome插件!!!只需三步,不用下载AxureRPExtensionforChrome插件!!!只需三步,不用下载AxureRPExtensionforChrome插件!!!打开原型......
  • C# 如何将Word、Excel、PPT转成PDF文件(使用Spire提供的组件)学习
    第一步:新建一个winform项目,下载Spire组件dll下载Spire.Doc、Spire.XLS、Spire.Presentation,路径:工具--NuGet包管理器--管理解决方案NuGet程序包1)Spire.Doc:word转成其它......