作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
目前我正在 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/
我是一名优秀的程序员,十分优秀!