【发布时间】:2016-07-28 14:50:08
【问题描述】:
我有 2 个文本框,一个用于用户名,另一个用于密码。
<input type="text" id="username">
<input type="text" id="password">
<input type="button" value="Login" onclick="authenticateUser()">
这是firebase代码:
function authenticateUser() {
var username = document.getElementById('username').value;
var password = document.getElementById('password').value;
database.ref('users/'+username).once('value').then(function(snapshot) {
var email = snapshot.val().email;
console.log(email);
});
}
上面写着:
Uncaught (in promise) TypeError: Cannot read property 'email' of null
如果用户名匹配,上面的 firebase 代码可以工作并获取电子邮件,但如果用户名不存在怎么办,如果不存在则抛出 TypeError,如何捕获该错误?
不幸的是,这不起作用:
function authenticateUser() {
var username = document.getElementById('username').value;
var password = document.getElementById('password').value;
database.ref('users/'+username).once('value').then(function(snapshot) {
var email = snapshot.val().email;
console.log(email);
}, function(error) {
console.log('Invalid Username');
});
}
在邮箱和密码认证的情况下,有catch
firebase.auth().createUserWithEmailAndPassword(email, password).catch(function(error) {
// Handle Errors here.
var errorCode = error.code;
var errorMessage = error.message;
// ...
});
在Java中,有类似的东西
catch(TypeError error) {
//Do whatever you want to do
}
【问题讨论】:
标签: javascript firebase firebase-realtime-database firebase-authentication