angular - Ionic 与 Firebase 数据库 Ref 被多次调用

标签 angular firebase ionic-framework firebase-realtime-database ionic3

我使用 Ionic3 和 AngularFire2 来与 Firebase 数据库交互。

我有以下代码:

ts

createMessage(chatItem: any, messageText: string): Promise<firebase.database.ThenableReference> {
    let offsetRef: firebase.database.Reference = firebase.database().ref(".info/serverTimeOffset");
    return new Promise<firebase.database.ThenableReference>((resolve) => {
        offsetRef.on("value", (snap: firebase.database.DataSnapshot) => {
            var offset = snap.val();
            var negativeTimestamp = (new Date().getTime() + offset) * -1;

            chatItem.readByReceiver = false;
            if (chatItem && !chatItem.$key && chatItem.key) {
                chatItem.$key = chatItem.key;
            }
            this.updateChat(chatItem);

            let ref: firebase.database.ThenableReference = this.af.database.list('/message').push({
                chatId: chatItem.$key,
                memberId1: this.me.uid,
                memberId2: this.you.uid,
                username: this.me.displayName,
                message_text: messageText,
                timestamp: firebase.database.ServerValue.TIMESTAMP,
                negativtimestamp: negativeTimestamp,
                readByReceiver: false
            });
            resolve(ref);
        });
    });
}

这工作正常,并向 Firebase 数据库写入一条消息。然而,我注意到在发送一条消息并在数据库中创建后,大约 20 分钟后又创建了一条新的但相同的消息。在代码中放置调试语句并等待它再次触发后,我注意到以下行导致代码执行多次:

offsetRef.on("value", (snap: firebase.database.DataSnapshot) => {
    // breakpoint getting executed more than once here
});

我希望每次调用该函数时它只执行一次。 offsetRef.on 我认为它的行为就像一个可观察的。

问题

确保代码只执行一次的最佳方法是什么?

谢谢。

最佳答案

你是对的,它的工作原理就像一个可观察的,每次值改变时它都会被触发。要确保它只运行一次,请使用 once('value')。 更多信息:https://firebase.google.com/docs/database/web/read-and-write#read_data_once

offsetRef.once("value").then((snapshot) => {
    // cod will be executed once here
});

关于angular - Ionic 与 Firebase 数据库 Ref 被多次调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44266452/

相关文章:

spring 5 webflux功能端点请求中不存在访问控制原始 header

javascript - 无法访问 anglarjs2+ 中动态创建的数组的对象属性

android - 如何将音频从 Firebase 加载到应用程序?

angular - 在根级别配置 ion-tabs 的选项卡

ionic-framework - ionic 实时重新加载不起作用

javascript - 未捕获( promise ): Error: Cannot read property of undefined

javascript - 动态加载外部 webpack 捆绑的 ngModule 作为路由处理程序

java - 使用 Firebase Android API 按嵌套数据排序查询时出现异常

android - Firebase Cloud Messaging 文档中的 "app server in my own environment"是什么意思?

Facebook Connect oauth 重定向 ionic 框架/cordova 上混合应用程序的 URI URL