javascript - 如何将firebase数据库查询输出到VueJs页面

标签 javascript firebase firebase-realtime-database vue.js vuejs2

目前我正在 Firebase 数据库中查询当前用户 username 。我希望该值显示在 <template> 内的页面上区域。浏览了文档,但对 Vue 仍然很陌生。

一切都会正确输出到控制台,我只是不确定下一步要在 <template> 中引用使用 mustache handle ,例如。 {{ user.username }}

  data() {
    return {
      userName: ''
    }
  },
  methods: {
    getName: function() {
      var userId = firebase.auth().currentUser.uid;
      return firebase.database().ref('users/' +
        userId).on('value', function(snapshot) {
        if (snapshot.val()) {
          var obj = snapshot.val();
          var userName = snapshot.val().username;
          console.log('username:', userName)
        }
      });
    }
  }

模板

<template>
 <span>{{ user.username }} (Output result of var userName here)</span>
</template>

最佳答案

您正在获取用户名,但没有更新 vue 实例对象(data 对象)。您可以调用 vueInstance.$set(vueInstance, 'propertyName', newPropertyValue); 来更新它 ( more details here ):

new Vue({
  el: '#app',
  data() {
    return {
      message: 'Hello Vue.js!',
      userName: ''
    }
  },
  methods: {
    getName: function() {
      var vueInstance = this;
      return setTimeout(function() {
        var userName = 'new username';
        vueInstance.$set(vueInstance, 'userName', userName);
        console.log('username:', userName)
      }, 2000);
    }
  }
});
<script src="https://unpkg.com/vue"></script>

<div id="app">
  <span>{{ message }}</span><br>
  <span>`{{ userName }}´ (Output result of var userName here)</span><br>
  <button @click="getName">Click me and wait for 2 seconds, the username will be updated</button>
</div>

关于javascript - 如何将firebase数据库查询输出到VueJs页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47980428/

相关文章:

javascript - 在javascript中返回一个html img标签

javascript - 在正则表达式中捕获重复的组

javascript - 如何在视频开始/停止时调整视频大小?

带有 firebase 计时问题的 javascript

firebase - 架构armv7的 undefined symbol : "_OBJC_CLASS_$_FIRApp"

javascript - Jquery获取和设置html字符串某些部分的css属性

java - 如何仅使用数组中数字大于 X 的文档制作 RecyclerView

android - 调试 Firebase 数据库

java - 从 Firebase 数据库中检索计数数据

firebase - 为什么此Firebase ".indexOn"不起作用?