繁体   English   中英

存储在localstorage中的Firebase用户不起作用? (JavaScript的)

[英]Firebase user stored in localstorage doesn't work? (javascript)

我在创建时将用户对象保存在localstorage中(为了确保我以后可以在authStateChanged之外的自定义函数中使用它):

const promise = auth.createUserWithEmailAndPassword(email, pass);
  promise.then(e => {
    var user = firebase.auth().currentUser;
    localStorage.setItem('fireUser', JSON.stringify(user));
    user.sendEmailVerification();
  }).catch(function(error) {
  var errorCode = error.code;
  var errorMessage = error.message;
  });

然后我在我的自定义函数中检索它,它像user.uid一样user.uid但是当用作user.delete()时它会给出错误“user.delete不是函数”,为什么会这样? 变量user在localStorage中看起来像这样:

在此输入图像描述

我的自定义功能:

var myTimer;
function validTimer(timerValid){
  var user = JSON.parse(localStorage.getItem('fireUser'));
  // var buser = firebase.auth().currentUser; <-- doesn't work here
  myTimer = setInterval(function() {
      timerValid++;
      localStorage.setItem('fireTimer', timerValid);
      if (timerValid == 22) {
        // delete in database
        var userId = user.uid;
        var ref = firebase.database().ref().child('users');
        ref.child(userId).once("value", function(snapshot){
          if (snapshot.exists()){
            database.ref("users/"+userId).remove();
          }
        });
        // delete account
        user.delete().then(function() {  // this says user.delete is not a function
        }).catch(function(error) {
        });
      }
  }, 1000);
}

当你将字符串化并解析回来时,它被剥夺了它的实例方法。 delete方法是firebase用户对象的实例方法。 在这种情况下,您的用户虽然看起来一样,但不是firebase用户。 这只是一个光秃秃的物体。

编辑

要通过Client SDK保持firebase用户,您需要使用firebase.auth().onAuthStateChanged()方法。 页面重新加载后不久,此方法将触发。 放在这里。 直接从网络开始指南

firebase.auth().onAuthStateChanged(function(user) {
  if (user) {
    // User is signed in.
    var displayName = user.displayName;
    var email = user.email;
    var emailVerified = user.emailVerified;
    var photoURL = user.photoURL;
    var isAnonymous = user.isAnonymous;
    var uid = user.uid;
    var providerData = user.providerData;
    // ...
  } else {
    // User is signed out.
    // ...
  }
});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM