记一次开源_大量SVG的高性能渲染

vscode-material-icon-theme 是一个有着广泛受众的vscode插件,用户可以给文件、目录设计图标,对属于vscode美化工具,我经常用这个工具区分架构,可以帮助理解目录结构。

不过每次我想找图标,都要去官方的仓库查看有哪些图标、对应的名称是什么,很麻烦,就开发了一个前端项目,托管在了vercel,方便随时打开搜索图标,这就是为什么开发vscode-material-icon-preview的原因。

在线使用

一个简单的项目,也打磨了一些细节:

  1. 根据用户时区判断明暗主题(用户手动设置后将不会再干预切换)
  2. 基于cookie的主题色ssr
  3. 用tanstack virtual高性能渲染大量dom节点
  4. 封装了img标签,加了缓存机制,防止多次发起网络请求读取svg
  5. 写了generator.ts构建脚本,在构建时获取svg的元信息,存到public下,每次push项目都会自动触发同步原仓库的图标更新
  6. 从svg里提取了HEX、RGB颜色,方便在前端计算颜色范围,实现了一个color filter,体验非常丝滑
  7. 图标的明暗版本切换。有的图标是有明暗版本的,在vscode中会自动切换,对于这些图标鼠标hover到图标上可以进行明暗版本切换预览

这个项目也踩到了一些坑,我本想把head做成Apple Liquid Glass的样子,但是死活都不能实现半透明,最后发现是因为我head样式无法感知到下层tanstack virtual内的图标,只能是在virtual内部做一个head,感觉会混乱职责,遂放弃。

相关推荐
人工智能训练6 小时前
【极速部署】Ubuntu24.04+CUDA13.0 玩转 VLLM 0.15.0:预编译 Wheel 包 GPU 版安装全攻略
运维·前端·人工智能·python·ai编程·cuda·vllm
会跑的葫芦怪6 小时前
若依Vue 项目多子路径配置
前端·javascript·vue.js
2601_949593656 小时前
基础入门 React Native 鸿蒙跨平台开发:模拟智能音响
react native·react.js·harmonyos
xiaoqi9227 小时前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin1233228 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头88219 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas1369 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠9 小时前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6
珑墨10 小时前
【Turbo】使用介绍
前端
军军君0110 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three