Vue项目 template报错undefined
解决vue项目中页面调用数据 在数据加载完毕之前出现undefined问题
在Vue项目中,当我们调用后台数据时,如果我们尝试在数据加载之前使用数据,就会遇到undefined的问题。
例如:一进入页面直接回显数据
<template>
<div>
{{ data[0].name }}
</div>
</template>
<script setup>
const data = []
</script>
此时因为 data
是空数组,所以会报错
如何解决
1、可以通过给个默认值的方式
<template>
<div>
{{ data[0].name }}
</div>
</template>
<script setup>
const data = [{name:'我是name'}]
</script>
在这个例子中,即使我们没有从后台加载数据,
data
数组也有一个默认值。这将确保我们在使用数据之前,数据已经有了一个值,避免了undefined的问题。
2、通过v-if
判断一下
<template>
<div v-if='data && data.length'>
{{ data[0].name }}
</div>
</template>
<script setup>
const data = []
</script>
在这个例子中,我们使用了
v-if
指令来检查data
数组是否存在并且是否有一个长度。这将确保我们在使用数据之前,数据已经存在,并且避免了undefined的问题。
返回
电梯