关于切换tab刷新列表,setup数据变化,模版列表仍为空数组问题定位

最近遇到的有点神奇的bug

  1. 父组件切换tab时,走了handleTabChange函数,发布事件
js 复制代码
<template>
    <PostList :type="activeTab" :key="activeTab"/>
</template>

<script setup>
import emitter from "~/src/utils/eventBus";

const activeTab = ref('all');

const handleTabChange = (tab) => {
  activeTab.value = tab;

  // 发布事件
  emitter.emit("articleParamsChanged", {
    type: tab,
  });
};

// 父组件
onMounted(() => {
  // 发送初始参数事件
  emitter.emit("articleParamsChanged", {
    type: activeTab.value,
  });
});

</script>
  1. 子组件接收事件后,刷新列表,模版里面list是[]
js 复制代码
<template>
    <PostItem v-for="item in articleList" :item="item" :key="item.id" /> 
</template>

<script setup>
import PostItem from "./PostItem.vue";
import { fetchList } from "@/api/app/index";
import emitter from "~/src/utils/eventBus";

const list = ref([]) // 列表
const pageNum = ref(1);
const pageSize = ref(5);

// 获取文章列表
const getList = async (isLoadMore = false) => {
  if (!isLoadMore) list.value = [];

  loading.value = true;
  try {
    // 请求参数
    const requestData = {
      page: pageNum.value,
      page_size: pageSize.value,
      type: queryParams.value.type,
      keyword: queryParams.value.searchValue,
    };

    const res = await fetchList(requestData);

    list.value = [...list.value, ...res.data.articles];
    console.log(list.value,'切换tab之后的list更新了')
    
    articleTotal.value = res.data.total;
  } catch (err) {
    console.log(err);
  } finally {
    loading.value = false;
  }
};

// 处理父组件参数变化事件
const handleParamsChanged = (params) => {
  Object.assign(queryParams.value, params);
  pageNum.value = 1; 
  getList();
};

onMounted(() => {
  // 订阅
  emitter.on("articleParamsChanged", handleParamsChanged);
});
</script>

分析

  1. 怀疑list数组没有重新更新,通过打印发现,数据已更新;
  2. 刚开始怀疑list响应式丢失,通过在Vue DevTool中查看发现list还具有响应式;
  3. 最后发现父组件调用子组件PostList上有key,去掉key问题解决。

解决方法

删除key

js 复制代码
// 父组件
<template>
    <PostList :type="activeTab" />
</template>

思考:为什么去掉key问题解决?

父组件先发送的emitter,然后因为key销毁重建子组件了,之后没在发送emitter,导致子组件出现list=[],去掉key则不会销毁重建子组件。

相关推荐
QQ1__8115175156 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态6 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子6 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室6 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI6 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing6 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者6 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册6 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李6 小时前
2026 年 Web 前端开发的 8 个趋势!
前端
里欧跑得慢6 小时前
15. Web可访问性最佳实践:让每个用户都能平等访问
前端·css·flutter·web