【前端功能点】字体包压缩

思路

  1. 创建一个前端项目,该项目只需要展示一个页面
  1. 点击提交,会修改font-spider.html这个文件
  2. 修改成功后,执行写好的shell.sh脚本生成压缩后的字体包
  3. 复制出压缩后的字体包使用即可

为什么要这么麻烦?这样做有什么好处?

原因

  1. font-spider 包对html文件中动态生成的文字无法提取,故前端三大框架均不能直接使用
  2. 当然也可以将字体压缩的逻辑放在开发的项目中,但这样的话,项目会感觉很乱,打包配置也要做些修改

好处

  1. 提取成新项目后,属于一个单独的项目,不会影响到业务项目
  2. 全程只有将文字复制到文本框这步算是最复杂的,整体操作简单,有可视化界面
  3. 其他项目也能通用,类似一个工具项目

大致讲下关键逻辑

  1. 点击提交,获取表单数据
  2. 对数据做处理(文字去重)
  3. 利用showOpenFilePicker该api调起文件上传,返回一个Promise,如果用户选了文件会得到文件信息
  4. 拿到文件信息的对象时,再调用文件信息的createWritable方法,该方法也是一个Promise用于创建一个可写流
  5. 将数据写入,并关闭写入流,弹出成功提示
  6. 新的html文件生成后,执行shell.sh文件
  7. 从fonts目录中复制压缩后的字体包即可

一下就是 以上关键逻辑的代码实现

js 复制代码
function submit() {
  const from = document.getElementById("form");
  const formData = new FormData(form);
  const chats = formData.get("words").trim();
  const name = formData.get("word-name").trim();
  let c = "";
  if (chats) {
    new Set(chats.split("")).forEach((v) => {
      c += v;
    });
  }
  if (c) {
    const whireFile = async () => {
      const title = document.getElementById("title");
      title.innerText = "加载中...... 请等待";
      title.style.color = "red";
      const [fileHider] = await window.showOpenFilePicker();
      const file = await fileHider.getFile();
      const writable = await fileHider.createWritable();
      await writable.write(
        `<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8" /><title>字蛛-压缩字体包</title><style>@font-face{font-family:${name};src: url("./fonts/${name}.TTF")}</style></head><body><div style="font-family: ${name};">${c}</div></body></html>`
      );
      await writable.close();
      title.innerText = " 字蛛-压缩字体包";
      setTimeout(() => {
        alert("加载完成");
      }, 300);
    };
    whireFile();
  } else {
    alert("请输入有效字符");
  }
}

shell脚本

js 复制代码
#! /bin/bash
echo "hello woild"
# 执行命令
font-spider ./font-spider.html

总结下

相关推荐
無名路人1 天前
uniApp 小程序 vue3 app.vue静默登录其他页面等待登录完成方式二
前端·微信小程序·ai编程
CoCo的编程之路1 天前
2026 前端效能飞跃:深度解析智能助手的页面构建最大化方案
前端·人工智能·ai编程·智能编程助手·文心快码baiducomate
JavaAgent架构师1 天前
前端AI工程化(一):AI通信协议深度解析
前端·人工智能
林恒smileZAZ1 天前
前端如何让图片、视频、pdf等文件在浏览器直接下载而非预览
前端·pdf
孙6903421 天前
electron播放本地任意格式的视频
前端·javascript
小小小小宇1 天前
设计稿转代码:如何将生成代码与内部组件库关联
前端
七牛云行业应用1 天前
别每个 AI 工具单独配了!MCP 一次搭建,Claude、Cursor、TRAE 全能用
前端
_xaboy1 天前
FormCreate 设计器 v6.3 正式发布:AI 表单助理3.0登场!
前端·vue.js·低代码·开源·表单设计器
胡志辉1 天前
邮件中点击“加载图片”,你的IP地址已经被泄漏
前端·后端·安全
openKaka_1 天前
reconcileChildren 深入:React 如何根据 ReactElement 构建子 Fiber
前端·javascript·react.js