IOS每次查询数据时,当前滚动的位置会跑到底部?

场景:(移动端)A模块内容在当前界面最后面展示时,若需要选择相应条件或切换页签时,IOS会一直显示在页面最底部,不会保留之前的位置?

问题出现在每次切换条件时会先清空数组,然后等接口请求回来后重新赋值,这样就会导致dom重新加载,界面内容重新刷新

解决这个问题其实可以利用空的内容占位,这样不管怎么查询,之前的位置都不会发生变化,那我是利用骨架屏处理的,根据界面结构然后写个最大的视图高度,等数据加载回来就隐藏

测试代码如下:

javascript 复制代码
<template>
  <div>
    <van-skeleton title :row="20" :loading="loading" />
    <div v-for="(item, index) in testList" :key="index">
      {{ item.name }}
    </div>
  </div>
</template>
javascript 复制代码
<script>
export default {
  name: 'test',
  data() {
    return {
      testList: [],
      loading: true,
    };
  },
  methods: {
    //获取数据
    getData() {
      this.testList = [{ name: '你' }, { name: '我' }, { name: '他' }];
      this.loading = false;
    },
  },
  created() {
  //一般在项目中会先清空数据然后调用接口赋值
    this.testList = [];
    this.getData();
  },
};
</script>
相关推荐
前端那点事18 小时前
深度解析:Vue中computed的实现原理(易懂不晦涩)
前端·vue.js
Mike_jia18 小时前
PortNote:可视化端口管理工具,让端口冲突成为历史
前端
前端那点事18 小时前
Vue中深克隆的3种实现方案(附详细注释+测试)
前端·vue.js
存在X19 小时前
claude code自定义模型
前端·claude
Highcharts.js19 小时前
赋能金融 SaaS|如何利用 Highcharts 与 Morningstar 数据构建顶级分析仪表盘
前端·金融·echarts·saas·bi·highcharts
啷咯哩咯啷19 小时前
纯本地运行的私人文档知识库
前端·人工智能·后端
❆VE❆19 小时前
基于 contenteditable 实现变量插入富文本编辑器
前端·javascript·vue.js
Aliex_git19 小时前
Nuxt 学习笔记(一)
前端·笔记·学习
烤麻辣烫19 小时前
json与fastjson
前端·javascript·学习·json
小陈同学呦19 小时前
JavaScript 深浅拷贝详解
前端·javascript