表现
设置了scroll-top的scroll-view组件,在组件所在vue实例data发生改变时会自动回弹到最上方
解决方案
打开 node_modules/mpvue/index.js, 在任意位置添加以下两个方法
function calcDiff(holder, key, newObj, oldObj) {
if (newObj === oldObj || newObj === undefined) {
return
}
if (newObj == null || oldObj == null || typeof newObj !== typeof oldObj) {
holder[key] = newObj
} else if (Array.isArray(newObj) && Array.isArray(oldObj)) {
if (newObj.length === oldObj.length) {
for (var i = 0, len = newObj.length; i < len; ++i) {
calcDiff(holder, key + '[' + i + ']', newObj[i], oldObj[i])
}
} else {
holder[key] = newObj
}
} else if (typeof newObj === ' ' && typeof oldObj === ' ') {
var newKeys = .keys(newObj)
var oldKeys = .keys(oldObj)
if (newKeys.length !== oldKeys.length) {
holder[key] = newObj
} else {
var allKeysSet = .create(null)
for (var i = 0, len = newKeys.length; i < len; ++i) {
allKeysSet[newKeys[i]] = true
allKeysSet[oldKeys[i]] = true
}
if ( .keys(allKeysSet).length !== newKeys.length) {
holder[key] = newObj
} else {
for (var i = 0, len = newKeys.length; i < len; ++i) {
var k = newKeys[i]
calcDiff(holder, key + '.' + k, newObj[k], oldObj[k])
}
}
}
} else if (newObj !== oldObj) {
holder[key] = newObj
}
}
function diff(newObj, oldObj) {
var keys = .keys(newObj)
var diffResult = {}
for (var i = 0, len = keys.length; i < len; ++i) {
var k = keys[i]
var oldKeyPath = k.split('.')
var oldValue = oldObj[oldKeyPath[0]]
for (var j = 1, jlen = oldKeyPath.length; j < jlen && oldValue !== undefined; ++j) {
oldValue = oldValue[oldKeyPath[j]]
}
calcDiff(diffResult, k, newObj[k], oldValue)
}
return diffResult
}
2.找到 throttleSetData 修改为
var throttleSetData = throttle(function (page, data) {
page.setData(diff(data, page.data));
}, 50);
3.找到 updateDataToMP 方法, 将 throttleSetData 的调用方式改为
throttleSetData(page, data);
希望官方早日修复,参考:
使用脏检查优化每次更新数据时都会传输大量数据的问题, 解决删除回退, 列表忽然滚动到顶部等问题
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
继续阅读与本文标签相同的文章
上一篇 :
贴上AI标签的评论区,正在剥夺我们平等言论的自由
下一篇 :
后数学时代 :机器人信天翁的兴起
-
月神脚本圈:互联网时代日新月异,引流脚本助你抓住商机
2026-05-18栏目: 教程
-
做外贸客户的货物被海关扣押了怎么办?
2026-05-18栏目: 教程
-
小学生发现丰巢快递柜刷脸取件bug 用照片就能打开
2026-05-18栏目: 教程
-
WIPO:中国专利申请量占世界一半 去年申请专利数量达154万件
2026-05-18栏目: 教程
-
Yotta主网上线在即,带你玩转YTA挖矿攻略!
2026-05-18栏目: 教程
