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

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

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

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

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

伪装组件

各种聊天工具里面

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

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

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

其他组件同理。

结语

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

相关推荐
左夕40 分钟前
分不清apply,bind,call?看这篇文章就够了
前端·javascript
Zha0Zhun1 小时前
一个使用ViewBinding封装的Dialog
前端
兆子龙1 小时前
从微信小程序 data-id 到 React 列表性能优化:少用闭包,多用 data-*
前端
滕青山1 小时前
文本行过滤/筛选 在线工具核心JS实现
前端·javascript·vue.js
时光不负努力1 小时前
编程常用模式集合
前端·javascript·typescript
恋猫de小郭2 小时前
Apple 的 ANE 被挖掘,AI 硬件公开,宣传的 38 TOPS 居然是"数字游戏"?
前端·人工智能·ios
小岛前端2 小时前
Node.js 宣布重大调整,运行十年的规则要改了!
前端·node.js
OpenTiny社区2 小时前
OpenTiny NEXT-SDK 重磅发布:四步把你的前端应用变成智能应用
前端·javascript·ai编程
梦想CAD控件2 小时前
在线CAD开发包结构与功能说明
前端·javascript·vue.js
张拭心2 小时前
春节后,有些公司明确要求 AI 经验了
android·前端·人工智能