Vuexfire serialize 选项未正确格式化数组

Posted

技术标签:

【中文标题】Vuexfire serialize 选项未正确格式化数组【英文标题】:Vuexfire serialize option not formatting array properlyVuexfire serialize 选项未正确格式化数组 【发布时间】:2020-12-27 14:08:49 【问题描述】:

我在查询集合时尝试添加所有 Firestore 文档 ID。我可以查询一个实例中的所有集合,但不能将它们的文档 ID 绑定到集合数组。

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

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
          )
        
      
    )
  )

然后我得到这个数据

[
   
      "name":"product1"
   ,
   
      "name":"product2"
   
]

我希望像这样将数据传递给 vuex:

[
   
      "id":"kmp1Ue8g0I130XZ3Ttqd",
      "name":"ll"
   ,
   
      "id":"qswtcdmnxNxbwmPNR1S3",
      "name":"fdsfs"
   
]

当我使用console.log(doc.id) 时,会显示上述 id,但我没有得到具有 id 值的预期数组,只是产品 姓名

【问题讨论】:

【参考方案1】:

这是因为你不能修改doc.data()返回的Object。

以下,使用对象扩展运算符创建一个新的普通对象,应该可以解决问题:

return 
   id: doc.id,
   ...doc.data()
 

【讨论】:

工作就像一个魅力!非常感谢

以上是关于Vuexfire serialize 选项未正确格式化数组的主要内容,如果未能解决你的问题,请参考以下文章

由于完成处理程序,单元格高度未正确计算

UITableView 单元格未正确显示

使用 vuexfire 动态绑定 firebase 集合列表

使用 Vuex 操作 Firebase 集合中的文档 [Vuex/Vuexfire]

为啥在 LibreOffice Calc 中未正确检测到单元格增量

iOS - 表格视图单元格未正确呈现