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>
相关推荐
山有木兮木有枝_10 小时前
手动封装移动端下拉刷新组件的设计与实现
前端
阳光阴郁大boy10 小时前
大学信息查询平台:一个现代化的React教育项目
前端·react.js·前端框架
小菜全10 小时前
uniapp新增页面及跳转配置方法
开发语言·前端·javascript·vue.js·前端框架
AlexMercer101210 小时前
[前端]1.html基础
前端·笔记·学习·html
白水清风10 小时前
关于Js和Ts中类(class)的知识
前端·javascript·面试
小菜全10 小时前
uniapp基础组件概述
前端·css·vue.js·elementui·css3
小天呐10 小时前
qiankun 微前端接入实战
前端·js·微前端
周航宇JoeZhou10 小时前
JP4-7-MyLesson后台前端(五)
java·前端·vue·elementplus·前端项目·mylesson·管理平台
Yaavi11 小时前
一个基于markdown的高性能博客模板
前端·开源·源码
艾小码11 小时前
手把手教你实现一个EventEmitter,彻底告别复杂事件管理!
前端·javascript·node.js