使用 foreignObject 在微信小程序实现 svg 头像生成

前言

这段时间想要自己做一个玩具小程序,在写首页时,我就已经做到了需要展示小程序的模块。开始我随便找了一张图片进行占位。但是当我涉及到开发后端接口,头像就不能单纯使用同一张图了,虽然小程序官方提供了获取用户头像的能力,但却需要用户自己授权。在用户还未授权的这段时间,我当然需要去提供一个好看(✧∀✧)的默认头像。

寻求头像生成的方法

我先是在搜索引擎寻找提供生成头像的一些网站:

1.

等等还是很多的,但是要不就是我觉得不符合我的审美爱好,要不就是不提供生成服务,要不就是太复杂,虽然我有找到一些提供api接口的,但是 emm 国内访问不了。自己搭建服务也过于麻烦了。

眼前一亮

我搜到找了开源库react-nice-avatar,而且我也相对比较喜欢他的样式,可以根据字符串(可以使用用户的唯一 openid)哈希来生成唯一头像。

可行性研究

我先将项目进行clone下来,运行下来很顺利,项目基于 React,生成的方式是基于对 svg 的替换以及同一个 div 的 position 来控制 svg 的位置。下面的是项目结构。

解决在微信中显示 svg

因为之前遇到过需要在微信中显示 svg 图表,是通过转换成 background-image 来显示 svg,并且还需要对 svghtml 结构的一些字符进行替换。但是其中我发现头像的结构并不单纯涉及到 svg,其中还存在一些 div 用于控制 div 的位置。

解决办法

这时刚好我同事就在我旁边,我把我的疑惑告诉了他,他立刻就对我提到了一个 html 标签 foreignObject

对于兼容性( ie 哒咩)

方案测试

然后我将 div 包裹在了foreignObject中,显示正常!

项目改造

现在的项目是基于 react 来进行运行的,但是我其实需要的只是最终的头像 html 文本。

其实我只要将组件全部改造成返回 svg 文本的一个函数,最终在 index.ts 中进行拼接,就可以在保证原本的逻辑下得到我需要的结果。

接下来就是无聊的改造时间.....

替换过程

这里举一个替换的例子:

chroma-js 的 替换,项目中依赖了这个库来进行颜色处理,但是其实用到的只有两处。所以我的想法就是在 utils 中来实现所用到的两个方法,减少库的引入。 继续寻求 Gpt 的帮助

然后再引入处理最后需要用于 background-image 的 data:image/svg+xml ,改造就 ok 了。

进行测试

最后用产出的粘贴到小程序进行测试。意料之中的

嗯,显示失败了,一片空白....

错误排查

控制变量

同一个配置,切换到最开始时正常的分支,以及现在改造后错误的分支。 通过同一个配置生成图像。

js 复制代码
export function transformToBgImg(svgHTML: string): string {
  const txt = svgHTML
    .replace(
      "<svg",
      ~svgHTML.indexOf("xmlns")
        ? "<svg"
        : "<svg xmlns='http://www.w3.org/2000/svg'"
    )
    .replace(/\s+/g, " ");
  return `data:image/svg+xml,${txt}`
}

通过上面的函数来得到去除尽量多的连续空白字符。便于后续对比。

对于产生的区别,借助文本 diff 工具。可以很明显的看出来。

错误原因

过程就不具体讲了,这里直接贴出来排除的结果

  1. react 中使用的 props,在替换时忘记给变量包上双引号""
  2. props 中的驼峰写法的转换成 xxx-xxxx
  3. 将自闭和标签进行替换 <path/> => <path></path>

运行结果

项目地址

github.com/ayuan-gy/ni...

相关推荐
m0_74824780几秒前
Flutter Intl包使用指南:实现国际化和本地化
前端·javascript·flutter
飞的肖4 分钟前
前端使用 Element Plus架构vue3.0实现图片拖拉拽,后等比压缩,上传到Spring Boot后端
前端·spring boot·架构
青灯文案111 分钟前
前端 HTTP 请求由 Nginx 反向代理和 API 网关到后端服务的流程
前端·nginx·http
m0_7482548816 分钟前
DataX3.0+DataX-Web部署分布式可视化ETL系统
前端·分布式·etl
ZJ_.27 分钟前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
GIS开发特训营32 分钟前
Vue零基础教程|从前端框架到GIS开发系列课程(七)响应式系统介绍
前端·vue.js·前端框架·gis开发·webgis·三维gis
Cachel wood1 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
学代码的小前端1 小时前
0基础学前端-----CSS DAY9
前端·css
joan_851 小时前
layui表格templet图片渲染--模板字符串和字符串拼接
前端·javascript·layui
还是大剑师兰特1 小时前
什么是尾调用,使用尾调用有什么好处?
javascript·大剑师·尾调用