首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >云功能文档副本

云功能文档副本
EN

Stack Overflow用户
提问于 2022-01-16 03:29:00
回答 2查看 51关注 0票数 0

云函数

  1. 我想读取文档并编辑一些字段以将其添加为新文档。我该怎么做?

const newData = value.data();//<<字段修改

  1. ,我能用copyWith ?

吗?

代码:

代码语言:javascript
复制
exports.productCopy = functions.https.onCall( async (data, context)=>{

    const uid = context.auth.uid;

 



    data.selectedProductId.forEach((docId){
        const productRef = admin.firestore()
                 .collection('products')
             
                 .doc(docId);
        const newProductRef = admin.firestore()
                         .collection('products')
                  
                         .doc();

        const product = await productRef.get().then((value)=>{
            const newData = value.data();

            newProductRef.add(value.data())
        });



    });


    return {status:'success', isError: false};


});
EN

回答 2

Stack Overflow用户

发布于 2022-01-16 04:30:51

首先,很好地知道每个文档都是不可变的,在变量中获得一个文档之后,您可以修改该变量,然后需要将/更新/修补新文档。

我的意思是您需要执行2个API调用,以便正确地将文档保存在数据库中。

票数 1
EN

Stack Overflow用户

发布于 2022-01-16 04:54:51

您不能在await块中真正使用forEach。如果要等待多个操作,请使用Promise.all()

应该是这样的:

代码语言:javascript
复制
exports.productCopy = functions.https.onCall((data, context) => {
    const uid = context.auth.uid;

    const promises = data.selectedProductId.map((docId) => {
        return admin.firestore() //  Return promise, which bubbles up
          .collection('products')                  
          .doc() //  You need to specify a document ID here, uid maybe?
          .get()
          .then((doc) => {
            const newData = doc.data();
            return admin.firestore() //  Return promise, which bubbles up
                 .collection('products')             
                 .doc(docId)
                 .add(value.data());
          });
    });

    return Promise.all(promises).then((results) => { //  Wait for all promises to resolve
      return { status:'success', isError: false };
    })
});

一般来说,最好不要将async/awaitthen()混为一谈,因为您很容易像以前那样陷入困境。在这里,只需使用承诺就可以使代码尽可能简单

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70727164

复制
相关文章

相似问题

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