使用 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...

相关推荐
Json_181790144802 分钟前
电商拍立淘按图搜索API接口系列,文档说明参考
前端·数据库
HerayChen7 分钟前
微信小程序混合 h5 wx.miniProgram是 undefined
微信小程序·小程序·h5
风尚云网25 分钟前
风尚云网前端学习:一个简易前端新手友好的HTML5页面布局与样式设计
前端·css·学习·html·html5·风尚云网
木子020428 分钟前
前端VUE项目启动方式
前端·javascript·vue.js
GISer_Jing30 分钟前
React核心功能详解(一)
前端·react.js·前端框架
捂月33 分钟前
Spring Boot 深度解析:快速构建高效、现代化的 Web 应用程序
前端·spring boot·后端
深度混淆40 分钟前
实用功能,觊觎(Edge)浏览器的内置截(长)图功能
前端·edge
Smartdaili China41 分钟前
如何在 Microsoft Edge 中设置代理: 快速而简单的方法
前端·爬虫·安全·microsoft·edge·社交·动态住宅代理
秦老师Q42 分钟前
「Chromeg谷歌浏览器/Edge浏览器」篡改猴Tempermongkey插件的安装与使用
前端·chrome·edge
滴水可藏海43 分钟前
Chrome离线安装包下载
前端·chrome