首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Vuexfire {序列化}选项未正确格式化数组

Vuexfire {序列化}选项未正确格式化数组
EN

Stack Overflow用户
提问于 2020-09-09 07:22:02
回答 1查看 214关注 0票数 0

当我查询一个集合时,我试图添加所有Fi还原文档Ids。我可以查询实例中的所有集合,但不能将它们的文档Ids绑定到集合数组。

这是我的代码,可以在名为product.js的vuex文件中查询用户的所有产品

代码语言:javascript
复制
import { firestoreAction } from 'vuexfire'
import { db } from '@/firebase/init'

const state = {
  products: []
}

const getters = {}

const actions = {
  init: firestoreAction( context  => {
    const allProducts = db.collection(`users/${context.rootState.authentication.user.uid}/products`)
    context.bindFirestoreRef(
      'products',
      allProducts, { 
        wait: true, 
        serialize: doc => {
          // console.log(doc.id) -returns the IDS I am looking for
          return Object.defineProperty(doc.data(), 'id', {
            value: doc.id
          })
        }
      }
    )
  })
}

然后我得到这些数据

代码语言:javascript
复制
[
   {
      "name":"product1"
   },
   {
      "name":"product2"
   }
]

我希望得到这样的数据传递给vuex:

代码语言:javascript
复制
[
   {
      "id":"kmp1Ue8g0I130XZ3Ttqd",
      "name":"ll"
   },
   {
      "id":"qswtcdmnxNxbwmPNR1S3",
      "name":"fdsfs"
   }
]

当我使用console.log(doc.id)时,上面的id会显示出来,但是我没有得到包含id值的预期数组,只有产品名称

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-09-09 09:06:39

这是因为您不能修改doc.data()返回的对象。

下面使用对象扩展操作符创建一个新的普通对象,应该可以做到这一点:

代码语言:javascript
复制
return {
   id: doc.id,
   ...doc.data()
 }
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63806612

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档