Polymer 1.x:如何在自定义行为中强制使用firebase-document获取数据

时间:2017-04-05 19:16:45

标签: firebase polymer polymer-1.0 polymerfire

我正在尝试使用自定义行为中动态的,命令式创建的firebase-document元素来获取数据。

我有以下代码。请注意第一个console.log按预期正确记录。但第二个从未记录任何东西。我哪里错了?

我-behavior.html
<link rel="import" href="../../bower_components/polymer/polymer.html">
<link rel="import" href="../../bower_components/polymerfire/polymerfire.html">
...
getUserLocalSeries: function(uid) {
  var doc = document.createElement('firebase-document');
  var path = ['users', uid, 'local'].join('/');
  doc.appName = 'app';
  doc.path = path;
  var _this = this;
  console.log('path', path); // Logs fine
  doc.addEventListener('response', function(e) {
    console.log('doc', doc.lastResponse); // Doesn't log
    _this.set('userLocalSeries', doc.lastResponse);
  });
  this.set('userLocalSeries', doc.data);
},

1 个答案:

答案 0 :(得分:3)

我强烈建议您仅使用Firebase JS SDK:

getUserLocalSeries: function(uid) {
  var path = ['users', uid, 'local'].join('/');
  var _this = this;
  firebase.database().ref(path).on('value', function(snap) {
    _this.set('userLocalSeries', snap.val());
  });
}

只要项目中有firebase-app,您就可以使用SDK。此示例要求您省略name中的firebase-app属性,但您也可以执行以下操作:而是firebase.app('app').database().ref()