Vue3---报错Uncaught (in promise) TypeError: Cannot read properties of undefined (reading ‘1‘)

问题原因:当goods刚定义时为空对对象, { }.category 的值就为 undefined

解决方法1:可选链的语法 ?.

解决方法2:v-if手动控制渲染时机,保证只有数据存在才渲染

<script setup>
import {getDetail} from "@/apis/detail";
import {onMounted, ref} from "vue";
import {useRoute} from "vue-router";

const goods = ref({})
const route = useRoute()
const getGoods = async () => {
    const res = await getDetail(route.params.id)
    goods.value = res.result
}
onMounted(() => getGoods())
</script>

<template>
 <!--  方法二  -->
<!--details为goods里的某一个字段-->
<div class="container" v-if="goods.detail">
      <el-breadcrumb separator=">">
           <el-breadcrumb-item :to="{ path: '/' }">首页</el-breadcrumb-item>
           <!--
               goods一开始是 {}, {}.category   -> undefined
               解决方法1:可选链的语法  ?.
               解决方法2:v-if手动控制渲染时机,保证只有数据存在才渲染
           -->
           <el-breadcrumb-item :to="{ path: `/category/${goods.category[1].id}` }">{{ goods.category[1].name }}
           <!-- 方法一  -->
           <!--<el-breadcrumb-item :to="{ path: `/category/${goods.categories?.[1].id}` }">{{ goods.categories?.[1].name }}-->
           </el-breadcrumb-item>
           <el-breadcrumb-item :to="{ path: `/category/sub/${goods.categories[0].id}` }">{{ goods.categories[0].name }}
           <!--<el-breadcrumb-item :to="{ path: `/category/sub/${goods.categories?.[0].id}` }">{{ goods.categories?.[0].name }}-->
           </el-breadcrumb-item>
      </el-breadcrumb>
</div>
</template>

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值