左边是列表,包含了群和成员,右侧是聊天窗口。点击群列表,右侧显示群聊窗口,点击学员,右侧显示私聊窗口。

群聊窗口和私聊窗口是不同的组件,但是窗口中的子组件,例如窗口的头部、中间内容部分、输入框都是复用的同一个组件。

一个花了很长时间才定位到问题的bug:

群聊窗口的表情包弹窗怎么也不显示,但是私聊窗口的表情包弹窗总是可以正常显示,复用的都是同一个组件,而且本地都是正常的,到线上就出现这个问题。

起初完全没有入口定位,最初猜测是数据渲染问题,输入框组件中加载表情包的逻辑代码在组件没有渲染之前就执行了,然后给这段逻辑代码加了定时器延时。

仍然无效。

这个bug停滞了几天,感觉自己的思维力不够,不知道怎么去定位这个bug,花时间去看了《思维力》这本书,然后再来看这个bug。

首先界定问题:

这里适合思维力里面说的界定问题中的第三条,探究问题本质。

问题本质是什么呢?本地是可以的,线上的不可以,那么就应该对比一下线上和本地有什么不同。线上的数据扒下来在本地运行一下,也不行,和线上表现一致;那么对比一下线上的数据和本地有什么不同,发现线上的和本地的字段格式不同在于多了一个id字段;已经找到了问题的苗头,利用思维力中的5w来探究问题的根本,为什么这个id字段会导致群聊和私聊的表情包显示有差异?公用的组件中拿这个id字段有做什么逻辑处理?去看下组件,发现给组件用id绑定了key。去掉key,问题解决了!!解决这个问题的关键其实是发现当从私聊切换到群聊时,表情包中的内容元素不见了,display为none,让我意识到有一种在代码中添加了控制元素显示与隐藏的逻辑,所以是代码中有写什么影响元素显示的逻辑。如果掌握了找问题的方法论,完全可以不依靠经验去找问题本质。

回到问题本身:

vue中为了快速渲染元素会复用已有元素,复用就意味着会保留上一次的状态,如果不希望元素复用,可以给元素绑定一个唯一的key。

那为什么这里给聊天框中的子组件——输入框组件绑定了一个key,会导致群聊窗口表情包不能正常渲染呢?

这个问题涉及到 Vue的虚拟DOM算法,这里就不总结了。

总结:

这个问题虽然是自己给自己挖了一个坑,但是在解决这个问题的过程中,我真正的意识到真正解决问题的高手,不是在于他有多了解这个问题,对这个问题相关的知识积累了多少经验(就像《思维力》这本书中说的一样),而在于他具备解决问题的模式,利用解决问题的逻辑去推断出问题的本质原因。

当我最后用理性的逻辑推出这个问题的根本的时候,我真的感受到了一阵成就感,这种把一个自己当初完全没办法解决的问题,最后靠逻辑解决的成就感真的太让人兴奋了。希望2019年能有更多这样的体验。

problem: 记一次聊天框的表情包弹框不显示的找问题过程的更多相关文章

  1. 使用mint-ui中弹框组件与原生弹框阻止父页面不滑动方法

    1,使用mint-ui框架中<mt-popup></mt-popup>,在组件中加入 lockScroll="true" 阻止父页面不滑动. 2,原生弹框中 ...

  2. Bootstrap学习笔记(9)--模态框(登录/注册弹框)

    说明: 1. 上来一个ul先把登录和注册两个链接扔进去,ul的类nav,navbar-nav是导航条,navbar-right让他固定在右侧.每个li的里面,data-toggle="mod ...

  3. iview框架 两侧弹框 出现第二层弹框 一闪而过的问题

    分析原因:寡人怀疑可能是,两层弹出框 采用的是一个开关值,发生了覆盖 解决方式 是在第二层弹框外套层计时器 源代码如下: 修改后为:

  4. vue中超简单的方法实现点击一个按钮出现弹框,点击弹框外关闭弹框

    效果图展示: View层 <template> <div> <div class="mask" v-if="showModal" ...

  5. 基于uni-app全端弹框组件uaPopup「兼容h5+小程序+app端|nvue」

    uniapp兼容多端自定义模态弹框组件UAPopup ua-popup 一款轻量级的uniapp自定义弹窗组件.汇集了android.ios和微信弹窗效果(msg消息.alert提示框.dialog对 ...

  6. 【前端开发】--js弹框

    js三种弹框 一.普通弹框 这类弹框就是仅仅是个提示作用,并不会做其它操作 关键词:alert()    这个没啥好说的,就是一个弹框.  二.判断弹框     这类框有一个判断作用 关键字:conf ...

  7. angularJs $mdDialog和$uibModal弹框关闭传值

    $mdDialog以一个点击button按钮出现弹框为例: $scope.btn=function($event,row){ var dScope = $scope.$new(true); dScop ...

  8. 如何优雅的写一个Vue 的弹框

    写Vue或者是react 都会遇见弹框的问题.也尝试了多种办法来写弹框,一直都不太满意,今天特地看了一下 Element UI 的源码,模仿着写了一个简易版. 大概有一下几个问题: 1.弹框的层级问题 ...

  9. html自定义弹框

    一.要实现的功能 1.弹框弹出时有遮罩 2.弹框内的文字过多时右侧有滚动条 3.根据执行结果变更弹框title的样式   二.具体实现 思路:定义一个有宽高的div,默认隐藏,当要显示时,设置为dis ...

随机推荐

  1. 集合List的排序

    自从出现了泛型和LINQ,对于集合的排序变得更简单了. //倒序 list.OrderByDescending(p=> p.a).ThenByDescending(p => p.b); / ...

  2. sqlserver智能提示插件-sql prompt(9.4.6)的安装及注册流程

    官网下在地址:https://www.red-gate.com/products/sql-development/sql-prompt/ CSDN下载地址(对应的版本是9.4.6,其中包含安装包和注册 ...

  3. 【5】用vector进行直接插入排序

    百分百自己编的程序,越来越觉得编程很好玩了. 但这算是第一次自己用vector这种不是那么无脑的方法编程,只能最多对3个数进行排序wwwww 今天我要回去搬宿舍了,等明天有时间,我一定要把bug找到! ...

  4. Java的URL类(一)

    转:https://www.cnblogs.com/blackiesong/p/6182038.html Java的URL类(一) Java的网络类可以让你通过网络或者远程连接来实现应用.而且,这个平 ...

  5. Java中返回类型方法名

    继承父类,子类含有两个分别为boy.Girl类名. 返回是需要返回方法 则返回变量名Person class Person { void eat() {} void speak() {} } clas ...

  6. vue-router+elelment-ui,实现导航栏激活高亮

    <el-menu :default-active="$route.path" class="el-menu-vertical-demo" backgrou ...

  7. 轻松理解AOP(面向切面编程)

    https://my.oschina.net/yanquan345/blog/203415

  8. python 8

    一.文件操作初识 1. path 文件路径 F:\文件.txt encoding 编码方式 utf-8, gbk ... mode 操作方式 只读,只写,读写,写读,追加... f1 = open(r ...

  9. DataTables中自增序号的实现

    最近工作中,一直在写前端的东西,一直以来前端都接触的少,所以侧重点也没放在这边,导致现在工作进展比较慢,果然偷懒是要不得的啊.... 今天刚写了一个在DataTables中增加一列自增序号,刚开始以为 ...

  10. position(3rd week blog)

    static:静态的默认属性,上(top)下(bottom)左(left)右(right)等参数不会执行没有影响.relative:此属性会根据上(top)下(bottom)左(left)右(righ ...