这个错误意味着什么?
当我将filteredData变量放入表的tr标记中时,就会发生这种情况。
<table id="table">
<tr>
<th>First name</th>
<th>Last Name</th>
<th>Email</th>
<th>Original email</th>
<th>Actions</th>
</tr>
<template>
<tr v-if="(fiteredData = '')">
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr
v-else
v-for="data in filteredData"
:key="data.ind_id"
:value="data.ind_id"
>
<td>{{ data.first_name }}</td>
<td>{{ data.last_name }}</td>
<td>{{ data.email }}</td>
<td>{{ data.email }}</td>
<td>
<button @click="sendProps(data)">
<i class="fa-regular fa-edit" aria-hidden="true"></i>
</button>
</td>
</tr>
</template>
</table>这是我的方法:
data() {
return {
fetchedData: "",
filteredData: "",
};
},
methods: {
searchResult(e) {
this.filteredData = this.fetchedData.filter((data) => {
return data.email.toLowerCase().includes(this.email.toLowerCase());
});
e.preventDefault();
console.log(this.filteredData);
}fetchedData从这里获取数据:
async mounted() {
await axios.get("http://localhost:5000/individuals").then((result) => {
this.fetchedData = result.data;
console.log(this.fetchedData);
});
},发布于 2022-04-24 08:24:53
我猜想:<tr v-if="(filteredData = '')">应该是:<tr v-if="filteredData === ''">,甚至是beter:v-if="!filteredData.length"。您拼写错了变量名,并且意外地将其设置为空字符串,而不是进行比较(我确信,我们都在那里)
在相关的说明中,我会将fetchedData和filteredData初始化为空数组,而不是字符串,因为v-for的目的是迭代对象和数组,而不是字符串(尽管它可能足够聪明地处理它)。
https://stackoverflow.com/questions/71986469
复制相似问题