ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

vue数组的不响应和对象数组属性的undefined

2021-04-23 02:02:13  阅读:272  来源: 互联网

标签:responseData vue console undefined onMounted 数组 name


vue数组内数据改变时页面不会响应而发生改变,需要使用root.$set(root是vue3.x对2.x的this的写法)


root.$set(responseData,i,data[i]);
responseData是接收的数组对象,i是排序,data是从后端拿下来的数据
这个地方v-for=“i in responseData.length”的i是从1开始而不是0

后端获取数据后的对象数组内属性出现undefined

由于onMounted是在setup之后,也就是后端数据的获取是在数据挂载之后,onMounted之前定义的const responseData = reactive([ {"name":""} ])。所以responseData 是没有以后的属性的,比如理应v-for的接收数据的responseData是有一个name属性的,但是responseData[1]却会发生name is undefined。这时候需要加上v-if判断是否渲染:

<div v-for="index in responseData.length+1" :key="index">
  <el-card shadow="hover" v-if="responseData[index]">
    ...
  <el-card>
</div>

由1,数组的变化甚至不会触发onUpdate和beforeUpdate

onMounted中调用的Promise函数在最后(异步)

onMounted(() => {
  getTaken().then(response => {
    console.log("foo")
  })
  .catch(error => {
    console.log(error)
  })
  console.log("coo")
})

打印出:foo coo

标签:responseData,vue,console,undefined,onMounted,数组,name
来源: https://www.cnblogs.com/rt8090/p/14692153.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有