firebase - Firebase交易的奇怪行为

我的firebase看起来像这样:

这是测试代码(咖啡脚本):

Firebase = require 'firebase'

ref = new Firebase 'https://my_firebase.firebaseio.com/items'

ref.once 'child_added', (snapshot) ->
  childRef = snapshot.ref()
  console.log "child_added", childRef.toString(), snapshot.val()
  childRef.transaction(
    (data) ->
      console.log 'transaction on data', data
      return if !data or data.my_key isnt 'my_val'
      data.my_key = 'new_val'
      return data
    ,
    (err, commited, snapshot) ->
      if err
        console.error 'error', err
        return
      console.log 'commited? '+commited
      console.log 'server data', snapshot.val()
    ,
    false
  )

并输出:
child_added https://my_firebase.firebaseio.com/items/item1 { my_key: 'my_val' }
transaction on data null
commited? false
server data null

transaction(...)的第三个参数为true时,也会发生同样的情况。
为了使此代码有效,我必须将 ref.once 'child_added', (snapshot) ->更改为 ref.on 'child_added', (snapshot) ->( once更改为 on)。更改后的输出为:
child_added https://my_firebase.firebaseio.com/items/item1 { my_key: 'my_val' }
transaction on data { my_key: 'my_val' }
commited? true
server data { my_key: 'new_val' }

似乎由于某种原因,当我使用 once时,数据未正确同步且本地快照未更新,并且事务“认为”引用下没有数据。是错误还是我做错了什么?我知道可以多次调用 updateFunction的事务,还知道第三个参数(我尝试过使用true和false选项),但是我仍然不明白为什么使用 once来获取孩子时事务为什么不起作用。

最佳答案

事务应最终成功,并以正确的数据状态运行,但最初将以“未缓存”状态运行,这意味着它将针对客户端的数据本地副本(可能是null)运行,尝试提交更改为服务器(这将失败),然后重试该事务。

这是正常现象,是可以预期的。但是,如果交易没有成功,我建议通过support@firebase.com与支持人员联系,以继续解决问题。