我是 Polymer 的新手,我正在尝试使用 Firebase-document 组件保存用户数据。
以下是相关的代码片段:
组件初始化:
<firebase-document id="document" app-name="nameoftheapp"
path="[[userDataPath]]" data="{{userData}}">
</firebase-document>
和javascript部分:
Polymer({
is: 'registration-view',
properties: {
userData: Object,
userDataPath: {
type: String,
notify: true
}
},
debugFunction: function () {
user = this.domHost.user;
this.userDataPath = '/users/' + user.uid;
this.userData.firstName = "fname";
this.userData.lastName = "lname";
console.log(user);
console.log(this.userDataPath);
this.$.document.save(this.userDataPath).then(function () {
console.log("success");
});
},
......
当我调用调试函数时,我得到
Uncaught (in promise) TypeError: c[b] is not a function(...)。
堆栈跟踪:
1) debugFunction @ registration-view.html:106
2) save @ firebase-document.html:82
3) (anonymous function) @ firebase-document.html:93
4) c @ firebase-app.js:formatted:939
该错误是在最小化的 firebase-app.js 文件中引发的,所以我不是很聪明。希望一切都正确配置。用户身份验证效果很好,应用名称也很好(如果不是应用程序未初始化错误将被抛出)。
我试图模拟数据库中的数据,而 firebase-document 没有加载它们。我设置了数据库规则,以便数据是公开的,以消除潜在的授权问题,但这并没有帮助。
{
"rules": {
// ".read": "auth != null",
".read": true,
// ".write": "auth != null"
".write": true
}
}
尝试2:
我找到了另一种保存数据的方法,代码如下:
<firebase-document id="document" app-name="doctor-appointment-system" log>
</firebase-document>
Javascript部分:
debugFunction: function () {
this.$.document.path = null;
this.$.document.data = {
'firstName': this.$.fninput.value,
'lastName': this.$.lninput.value
};
console.log('users/' + this.domHost.user.uid);
this.$.document.save('users', this.domHost.user.uid);
},
使用此设置,我遇到了另一个错误。这是控制台的输出:
用户/Z5uAEYO2S1g2JYClpkk1Vtw130i2
app-storage-behavior.html:350 将用户/Z5uAEYO2S1g2JYClpkk1Vtw130i2 的 Firebase 值设置为对象 {firstName: "", lastName: ""}
firebase-database-behavior.html:61 Uncaught (in promise) TypeError: Cannot read property 'ref' of undefined(...)_setFirebaseValue
它在 firebase-database-behaviour.html 中的以下行失败:
var result = this.db.ref(path).set(leaf ? value.$val : value);
看起来配置有问题,但身份验证工作正常,所以我一无所知。
我坚持这个,所以任何帮助将不胜感激。
谢谢,扬