uni-app索引列表被父组件覆盖后点击右侧锚点无效

发布于 1周前 作者 gougou168 来自 Uni-App

uni-app索引列表被父组件覆盖后点击右侧锚点无效

做组件的时候能不能走点心,大部分情况是在pop组件下使用,现在在pop组件下使用的话点击右侧字母不生效,没有slot,也没有考虑多个业务场景就开发出来了,三四年之前就有人提过bug也不予修复。(顺便问一句:哪个傻叉写的)

1 回复

在uni-app中,如果你遇到索引列表(Index List)被父组件覆盖后,点击右侧锚点无效的问题,这通常是因为页面布局或层级(z-index)管理不当导致的。为了确保索引列表和锚点能够正常工作,你可以通过调整样式和层级关系来解决这个问题。

以下是一个简化的代码示例,展示了如何在uni-app中实现索引列表,并确保锚点点击有效:

<template>
  <view class="container">
    <!-- 父组件内容 -->
    <view class="parent-content">
      <!-- 其他内容 -->
    </view>

    <!-- 索引列表 -->
    <scroll-view scroll-y="true" class="index-list-wrapper">
      <view class="index-bar" @touchstart="handleTouchStart">
        <view v-for="(item, index) in indexList" :key="index" class="index-item" @click="scrollToSection(item)">
          {{ item }}
        </view>
      </view>
      <view class="content-wrapper">
        <view v-for="(section, index) in sections" :key="index" :id="'section-' + index" class="section">
          <text>{{ section }}</text>
        </view>
      </view>
    </scroll-view>
  </view>
</template>

<script>
export default {
  data() {
    return {
      indexList: ['A', 'B', 'C', 'D', 'E', 'F', 'G'],
      sections: [
        'Section A Content',
        'Section B Content',
        'Section C Content',
        // ... more sections
      ]
    };
  },
  methods: {
    scrollToSection(letter) {
      const targetId = this.sections.findIndex(section => section.startsWith(letter));
      if (targetId !== -1) {
        this.$refs.scrollView.scrollTo({
          scrollTop: this.$refs[`section-${targetId}`].offsetTop,
          duration: 300
        });
      }
    },
    handleTouchStart(e) {
      // 处理触摸开始事件,如果需要的话
    }
  }
};
</script>

<style scoped>
.container {
  position: relative;
}
.parent-content {
  position: absolute;
  top: 0;
  left: 0;
  right: 20px; /* 留出索引列表的空间 */
  height: 100%;
  z-index: 1; /* 确保索引列表在其上方 */
}
.index-list-wrapper {
  position: absolute;
  top: 0;
  right: 0;
  width: 20px; /* 索引列表的宽度 */
  height: 100%;
  z-index: 2; /* 确保索引列表在最上层 */
}
.index-bar {
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5); /* 半透明背景 */
}
.index-item {
  /* 样式定义 */
}
.content-wrapper {
  padding-right: 20px; /* 确保内容不被索引列表覆盖 */
}
.section {
  /* 样式定义 */
}
</style>

在这个示例中,我们使用了scroll-view组件来包含索引列表和内容区域,并通过z-index来管理层级关系。同时,我们确保内容区域有足够的空间不被索引列表覆盖。这样,点击索引列表的锚点时,应该能够正确地滚动到对应的内容区域。

回到顶部