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

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

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

由于很久没更新过了,只能参考 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 的消息状态改为已经被操作过~

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

伪装组件

各种聊天工具里面

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

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

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

其他组件同理。

结语

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

相关推荐
凤凰战士芭比Q28 分钟前
web中间件——(二)Nginx(高级功能、优化)
前端·nginx·中间件
阿珊和她的猫31 分钟前
表单数据验证:HTML5 自带属性与其他方法的结合应用
前端·状态模式·html5
谷粒.2 小时前
Cypress vs Playwright vs Selenium:现代Web自动化测试框架深度评测
java·前端·网络·人工智能·python·selenium·测试工具
小飞侠在吗7 小时前
vue props
前端·javascript·vue.js
DsirNg8 小时前
页面栈溢出问题修复总结
前端·微信小程序
小徐_23338 小时前
uni-app 也能远程调试?使用 PageSpy 打开调试的新大门!
前端·微信小程序·uni-app
大怪v8 小时前
【Virtual World 03】上帝之手
前端·javascript
别叫我->学废了->lol在线等10 小时前
演示 hasattr 和 ** 解包操作符
开发语言·前端·python
霍夫曼10 小时前
UTC时间与本地时间转换问题
java·linux·服务器·前端·javascript
DARLING Zero two♡11 小时前
浏览器里跑 AI 语音转写?Whisper Web + cpolar让本地服务跑遍全网
前端·人工智能·whisper