Firebase具有子值的多路径原子更新?

时间:2018-07-27 01:08:44

标签: javascript reactjs firebase firebase-realtime-database multipath

我成功更新了该用户的个人资料图片以及该功能发布的所有评论:

export const storeUserProfileImage = (url) => {
    const { currentUser } = firebase.auth();

        firebase.database().ref(`/users/${currentUser.uid}/profilePic`)
        .update({ url });

        firebase.database().ref('reviews')
          .orderByChild('username')
          .equalTo('User3')
          .once('value', (snapshot) => {
            snapshot.forEach((child) => {
              child.ref.update({ profilePic: url });
            });
        });
  };

我知道我应该使用原子更新来做到这一点,以便同时更新数据(以防用户离开应用程序或其他出现问题的情况)。我对查询子值时如何完成此操作感到困惑。

任何帮助或指导将不胜感激!

1 个答案:

答案 0 :(得分:1)

声明一个变量以存储所有更新。在侦听器循环中阅读更新时,请添加它们。循环结束后,运行原子更新。

export const storeUserProfileImage = (url) => {
    const { currentUser } = firebase.auth();

        firebase.database().ref('reviews')
          .orderByChild('username')
          .equalTo('User3')
          .once('value', (snapshot) => {

            var updates = {};
            updates[`/users/${currentUser.uid}/profilePic`] = url;

            snapshot.forEach((child) => {
              updates[`/reviews/${child.key}/profilePic`] = url;
            });

            firebase.database().ref().update(updates);

        });
};