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>
相关推荐
excel10 小时前
Vue 编译器中的静态节点缓存机制:cacheStatic() 深度解析
前端
用户114818678948410 小时前
深入理解 V8 引擎--理解版
前端
inx17710 小时前
深入理解 CSS 盒模型:box-sizing 的正确使用姿势
前端·css
技术钱10 小时前
react antdesign实现表格嵌套表单
前端·react.js·前端框架
小p10 小时前
react学习4:CSS Modules 样式
前端·react.js
东华帝君10 小时前
小型列表是否需要拆分成服务器组件
前端
卍郝凝卍10 小时前
物联网卡摄像头从前端至后台的实现过程
前端·物联网·视频解决方案
疯狂暴龙GG帝10 小时前
项目中使用el-table实现行合并及合并后序号不连续解决方案
前端·vue.js
东华帝君10 小时前
React Hook Form —— useForm 和 FormProvider+useFormContext
前端
小p11 小时前
react学习3: 闭包陷阱
前端·react.js