u-view 的u-calendar 组件设置默认日期后,多次点击后,就不滚动到默认日期的位置

**场景:**uniapp开发微信小程序 vue2 uview版本:2.0.36 ; u-calendar 组件设置默认日期后 我打开弹窗,再关闭弹窗, 重复两次 就不显示默认日期了

在源码中找到这个位置进行打印值,根据出bug前后的值进行分析,发现,获取dom信息时候,获取的height有时候是整数有时候是小数,但是差的不大,应该是dom精度问题,属于正常情况,但是就是这个导致的问题,如果两次获取的height值不一样,就是正常的,如果两次获取的height值一样,那么就会出现这个bug, 这里要提一下,这个获取的height值是在后代组件中获取的,然后传递给祖先组件,在祖先组件中赋值给scroll-view组件的scroll-top属性。所以有个大胆的猜测,两次获取的值一样然后赋值给scroll-view的scroll-top属性,会不会第二次赋值的时候,因为和上次的值一样,进而缓存了,相当于就没有给scroll-view的scroll-top属性赋值上去,相当于没生效。

故改源码,设置一个布尔值,然后在祖先组件拿到后代组件传递上来的这个值的时候,进行动态加减0.0001几乎不印象值,但是可以实现每次值都不一样,最后测试完,发现果然好了。询问了u-view的社区维护人员,被告知是u-view的bug。也没时间追根溯源了。能解决就行。下面具体修改了源码的位置。

/uni_modules/uview-ui/components/u-calendar/u-calendar.vue文件下:

以下是源码打印日志的文件路径:/uni_modules/uview-ui/components/u-calendar/month.vue

上图中this.$uGetRect方法定义文件路径:/uni_modules/uview-ui/libs/mixin/mixin.js

相关推荐
发现一只大呆瓜11 分钟前
虚拟列表:支持“向上加载”的历史消息(Vue 3 & React 双版本)
前端·javascript·面试
css趣多多28 分钟前
ctx 上下文对象控制新增 / 编辑表单显示隐藏的逻辑
前端
_codemonster34 分钟前
Vue的三种使用方式对比
前端·javascript·vue.js
寻找奶酪的mouse35 分钟前
30岁技术人对职业和生活的思考
前端·后端·年终总结
梦想很大很大43 分钟前
使用 Go + Gin + Fx 构建工程化后端服务模板(gin-app 实践)
前端·后端·go
We་ct1 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
张3蜂1 小时前
深入理解 Python 的 frozenset:为什么要有“不可变集合”?
前端·python·spring
无小道1 小时前
Qt——事件简单介绍
开发语言·前端·qt
广州华水科技1 小时前
GNSS与单北斗变形监测技术的应用现状分析与未来发展方向
前端
code_YuJun1 小时前
corepack 作用
前端