Petua untuk membina aplikasi surat berita yang cekap menggunakan Vue dan Firebase Cloud Firestore
Abstrak:
Artikel ini akan memperkenalkan cara menggunakan Vue.js dan Firebase Cloud Firestore untuk membina aplikasi surat berita yang cekap. Kami akan menggunakan Vue.js sebagai rangka kerja bahagian hadapan dan berkomunikasi dengan Firebase Cloud Firestore untuk komunikasi pangkalan data masa nyata. Dalam artikel ini, kami akan memperkenalkan proses secara terperinci daripada mencipta projek Firebase, menyediakan pangkalan data masa nyata Firestore, menulis komponen Vue dan mengikat data serta penyegerakan masa nyata.
Persediaan persekitaran projek Vue:
Sebelum membina projek Vue, kami perlu memastikan Node.js dan Vue CLI telah dipasang. Gunakan Vue CLI untuk mencipta rangka projek asas Vue dengan cepat. Pergi ke terminal (baris arahan) dan laksanakan arahan berikut:
vue create news-app
Ini akan mencipta projek Vue yang dipanggil news-app. Seterusnya, pergi ke folder projek dan jalankan arahan berikut untuk memasang SDK Firebase:
cd news-app npm install firebase
Selepas pemasangan selesai, kami juga perlu mengkonfigurasi SDK Firebase. Buat fail baharu yang dipanggil firebase.js
, import Firebase SDK dan konfigurasikan projek: firebase.js
的文件,在其中引入Firebase SDK并配置项目:
import firebase from 'firebase/app' import 'firebase/firestore' const firebaseConfig = { // 替换为你自己的配置信息 } firebase.initializeApp(firebaseConfig) export const db = firebase.firestore()
将firebaseConfig对象的值替换为你在Firebase控制台上的项目配置信息。
创建Vue组件:
接下来,我们开始创建Vue组件。在src/components文件夹中,我们创建一个名为NewsList.vue
的文件,并在其中实现展示新闻列表的组件:
<template> <div> <h1>时事新闻</h1> <ul> <li v-for="news in newsList" :key="news.id"> {{ news.title }} </li> </ul> </div> </template> <script> import { db } from '@/firebase' export default { data() { return { newsList: [] } }, mounted() { db.collection('news') .orderBy('timestamp', 'desc') .limit(10) .onSnapshot(querySnapshot => { this.newsList = querySnapshot.docs.map(doc => doc.data()) }) } } </script>
在这个组件中,我们通过调用db.collection('news')
来获取名为news的集合数据。我们使用orderBy('timestamp', 'desc')
来按照时间戳的降序排列数据,并使用limit(10)
来限制只显示最新的10条新闻。使用onSnapshot
函数可以实时监听数据的变化,并将获取的数据映射到newsList
<template> <div id="app"> <NewsList /> </div> </template> <script> import NewsList from './components/NewsList.vue' export default { components: { NewsList } } </script>
Mencipta komponen Vue:
NewsList.vue
dan melaksanakan komponen yang memaparkan senarai berita: npm run serve
db.collection('news ')
untuk mendapatkan data pengumpulan bernama berita. Kami menggunakan orderBy('timestamp', 'desc')
untuk mengisih data dalam tertib menurun cap waktu dan menggunakan had(10)
untuk mengehadkan paparan kepada yang terkini sahaja 10 berita. Gunakan fungsi onSnapshot
untuk memantau perubahan data dalam masa nyata dan memetakan data yang diperoleh kepada atribut data newsList
.
Dalam App.vue, kami mula mengimport komponen dan menggunakannya dalam templat:
rrreee
Atas ialah kandungan terperinci Petua untuk membina apl surat berita yang berkesan menggunakan Vue dan Firebase Cloud Firestore. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!