关于假装我是一个高级组件这件事

关于假装我是一个高级组件这件事

最近在做公司的小程序聊天部分。

由于很久没更新过了,只能参考 APP 的实现。

这一看不知道,发现个很无语的事情。

大哥,你是地图啊?

咱看看这个截图

这里我一共发了三条地图消息。

但是有个很抽象的事情:

咱的 APP选手,直接加载了三个地图组件到当前页。

于是,我就问他了,是不是用户发了 100个定位,就初始化 100个?

APP:Yes!

问题所在

如果是在 APP 端,做了消息虚拟滚动的,又因为现在各位阿宝的手机配置越来越高。问题也不算太大。

当这个东西,出现在小程序中呢?

  1. 首先,小程序本来就是个性能垃圾的产物
  2. 其次,我们还用的是uniapp-vue2版本写的。。我也不知道这个版本怎么做虚拟滚动。。。
  3. 然后,我是小程序垃圾选手,我只会 pc/web/服务端
  4. 最后,加载这么多地图组件到页面上本来就是个很抽象的事情好伐!

我来假装组件

如何解决?

很简单的拉,我用图片替换这个地图不就好了?

比如:

这条消息发送了一个经纬度:[111,222]

那么,我就到利用某些方法,把这个坐标的贴图获取到。

最后组装成为一个图文消息。

岂不快哉?

用户觉得,我发了这么多地图消息,不卡诶? 交互很不错嘛。

哈哈哈

引入其他的一些思考

当然,我们在开发的时候会遇到各种类型的问题,这些时候,参考竞品是很不错的选择~

交互式消息

金三银四的时候,大家在用某 ss 的时候,发消息。

HR: 向你发起了一个面试邀请~ ✔ or ❌

这个时候你只需要点击一个 ✔就能处理这个消息

这个时候是怎么做到的呢?

在不利用本地数据库的情况下,要么存储到后端数据库。

要么?我把问题的 id 保留到我接受的这条消息中。

其实就是:

javascript 复制代码
messageA = {
id:1,
content:'你是否接受. ✔ ❌'
}
messageB = {
id:2,
coentent:'我已接受您的面试邀请~',
extIfo: {
extId :1,
extOption: '✔'
}
}

那么我在渲染消息的时候,发现我这条消息处理了 id 为 1 的这条消息。我们就可以返回去,把id 为 1 的消息状态改为已经被操作过~

不建议使用各种本地数据库留存操作数据。因为要涉及到多端、多设备同步。你存你 **的本地!

伪装组件

各种聊天工具里面

什么在线文档、地图、视频组件。

其实都可以用图文消息伪装~

把文档在服务端处理,生成一张预览图。直接插入聊天中,效果也是杠杠的~

其他组件同理。

结语

赶紧把你代码里面那些可以被假装的组件修改了~

相关推荐
lizhongxuan20 小时前
Claude Code 防上下文爆炸:源码级深度解析
前端·后端
柳杉1 天前
震惊!字符串还能这么玩!
前端·javascript
是上好佳佳佳呀1 天前
【前端(五)】CSS 知识梳理:浮动与定位
前端·css
wefly20171 天前
纯前端架构深度解析:jsontop.cn,JSON 格式化与全栈开发效率平台
java·前端·python·架构·正则表达式·json·php
我命由我123451 天前
React - 类组件 setState 的 2 种写法、LazyLoad、useState
前端·javascript·react.js·html·ecmascript·html5·js
自由生长20241 天前
IndexedDB的观察
前端
IT_陈寒1 天前
Vite热更新坑了我三天,原来配置要这么写
前端·人工智能·后端
斯班奇的好朋友阿法法1 天前
离线ollama导入Qwen3.5-9B.Q8_0.gguf模型
开发语言·前端·javascript
掘金一周1 天前
每月固定续订,但是token根本不够用,掘友们有无算力焦虑啊 | 沸点周刊 4.2
前端·aigc·openai
小村儿1 天前
连载加餐01-claude code 源码泄漏 ---一起吃透 Claude Code,告别 AI coding 迷茫
前端·后端·ai编程