【发布时间】:2018-10-25 10:22:23
【问题描述】:
我不明白如何将 firebase 数据导入 vue...一旦我得到答案,我很高兴删除这个问题或辞去我作为程序员的工作;)
我知道数据是异步的,所以 vue 试图在接收到数据之前渲染组件。但是,我不知道如何让它等待。示例将不胜感激。我试过阅读文档,但我就是不明白。
这是一个很小的应用程序,它显示我们公司的停车场并将用户的水龙头(汽车)位置保存到火力基地(我们厌倦了忘记我们停在哪里)。感谢您的帮助!
哦,我使用 set() 是因为一次只需要保存一个汽车位置,所以每次用户在屏幕上点击一个新位置时,数据都会被覆盖。
<template>
<div id="app">
<span id="marker" class="fas fa-times" :style="{ left: leftCoord, top: topCoord }"></span>
<img @click="saveCoordinates($event)" src="./assets/parking-lot.jpg">
</div>
</template>
<script>
import firebase from 'firebase'
const config = {
apiKey: 'MY-API-KEY',
authDomain: 'MY-APP.firebaseapp.com',
databaseURL: 'https://MY-APP.firebaseio.com',
projectId: 'MY-APP',
storageBucket: 'MY-APP.appspot.com',
messagingSenderId: '1234567890'
}
const app = firebase.initializeApp(config)
const db = app.database()
const locationRef = db.ref('location')
export default {
name: 'app',
firebase: {
location: locationRef
},
mounted () {
this.leftCoord = this.location.leftCoord
this.topCoord = this.location.topCoord
},
data () {
return {
leftCoord: '',
topCoord: ''
}
},
methods: {
saveCoordinates: function (clickEvent) {
const coordinates = {
leftCoord: clickEvent.layerX,
topCoord: clickEvent.layerY
}
this.location.set(coordinates)
}
}
}
</script>
【问题讨论】:
-
有些事情我不完全理解:您说“vue 正在尝试在接收到数据之前渲染组件”但是在您共享的代码中没有对 读取数据库,只是一个触发写入的按钮。你能澄清一下吗?究竟是什么问题?
-
在挂载的钩子中,我尝试使用来自 firebase db 的引用设置标记的左坐标和上坐标,然后将这些更改与标记中的标记中的样式绑定一起应用模板。我收到的最初错误是 .set() 不是函数。
-
好的,我明白了,感谢您的指点!在挂载的钩子中,如果你这样做
console.log(this.location)会得到什么? -
如果你这样做
this.leftCoord = locationRef.leftCoord -
等一下,我正在寻找解决方案
标签: firebase firebase-realtime-database vue.js vuefire