


Comment utiliser Vue et Firebase Cloud Firestore pour implémenter une application de newsletter avec synchronisation des données en temps réel
Comment utiliser Vue et Firebase Cloud Firestore pour implémenter une application de newsletter avec synchronisation des données en temps réel
Introduction :
À l'ère du numérique, l'acquisition d'informations en temps réel est devenue l'un des besoins importants. La fonction de synchronisation en temps réel des applications de newsletter aide les utilisateurs à rester informés des dernières nouvelles, événements et mises à jour. Cet article expliquera comment utiliser Vue.js et Firebase Cloud Firestore pour implémenter une application de newsletter avec synchronisation des données en temps réel et fournira des exemples de code correspondants.
1. Qu'est-ce que Vue.js et Firebase Cloud Firestore
Vue.js est un framework JavaScript populaire pour la création d'interfaces utilisateur. Il est facile à apprendre, flexible et efficace, et est largement utilisé dans le développement d’applications monopage et d’applications mobiles.
Firebase Cloud Firestore est un service de base de données cloud flexible et en temps réel. Il fournit un moyen simple de stocker et de synchroniser les données d'une application sans avoir besoin de créer et de gérer vous-même un serveur principal.
2. Préparation du projet
-
Créer un projet Vue.js
Tout d'abord, créez un nouveau projet Vue.js via Vue CLI. Ouvrez un terminal et exécutez la commande suivante :vue create times-news-app
Copier après la connexionSélectionnez vos options de configuration préférées et attendez la fin de la création du projet.
- Configuration de Firebase Cloud Firestore
Créez un nouveau projet dans la console Firebase et ajoutez la base de données Cloud Firestore. Obtenez vos informations de configuration Firebase dans les paramètres du projet.
Ouvrez le projet Vue.js, créez un fichier nommé .env.local
dans le répertoire racine du projet et ajoutez les informations de configuration suivantes au fichier : .env.local
的文件,并将以下配置信息添加到该文件中:
VUE_APP_FIREBASE_API_KEY=YOUR_API_KEY VUE_APP_FIREBASE_AUTH_DOMAIN=YOUR_AUTH_DOMAIN VUE_APP_FIREBASE_DATABASE_URL=YOUR_DATABASE_URL VUE_APP_FIREBASE_PROJECT_ID=YOUR_PROJECT_ID VUE_APP_FIREBASE_STORAGE_BUCKET=YOUR_STORAGE_BUCKET VUE_APP_FIREBASE_MESSAGING_SENDER_ID=YOUR_MESSAGING_SENDER_ID VUE_APP_FIREBASE_APP_ID=YOUR_APP_ID
将YOUR_API_KEY
、YOUR_AUTH_DOMAIN
等替换为你在Firebase控制台中获得的实际值。
三、创建Vue组件
首先,我们需要创建两个Vue组件:一个用于显示新闻列表,另一个用于发布新的新闻。
NewsList.vue
<template> <div> <h1>时事新闻</h1> <ul> <li v-for="newsItem in newsList" :key="newsItem.id"> {{ newsItem.title }} </li> </ul> </div> </template> <script> import db from '@/firebaseConfig.js'; export default { data() { return { newsList: [] }; }, created() { db.collection('news') .orderBy('timestamp', 'desc') .onSnapshot((snapshot) => { this.newsList = snapshot.docs.map((doc) => { return { id: doc.id, title: doc.data().title }; }); }); } }; </script>
Copier après la connexionNewNews.vue
<template> <form @submit.prevent="submitNews"> <h2>发布新闻</h2> <input type="text" v-model="newsText" placeholder="请输入新闻标题" /> <button type="submit">发布</button> </form> </template> <script> import db from '@/firebaseConfig.js'; export default { data() { return { newsText: '' }; }, methods: { submitNews() { db.collection('news') .add({ title: this.newsText, timestamp: new Date() }) .then(() => { this.newsText = ''; }) .catch((error) => { console.error('发布新闻失败:', error); }); } } }; </script>
Copier après la connexion
四、配置路由和样式
在src/router/index.js
文件中配置路由:
import Vue from 'vue'; import VueRouter from 'vue-router'; import NewsList from '@/views/NewsList.vue'; import NewNews from '@/views/NewNews.vue'; Vue.use(VueRouter); const routes = [ { path: '/', name: 'NewsList', component: NewsList }, { path: '/new', name: 'NewNews', component: NewNews } ]; const router = new VueRouter({ mode: 'history', base: process.env.BASE_URL, routes }); export default router;
在src/App.vue
文件中设置基本样式:
<template> <div id="app"> <router-link to="/">新闻列表</router-link> <router-link to="/new">发布新闻</router-link> <router-view /> </div> </template> <style> #app { font-family: Arial, Helvetica, sans-serif; text-align: center; } </style>
五、集成Firebase和Vue应用
在src/firebaseConfig.js
文件中配置Firebase:
import firebase from 'firebase/app'; import 'firebase/firestore'; const firebaseConfig = { apiKey: process.env.VUE_APP_FIREBASE_API_KEY, authDomain: process.env.VUE_APP_FIREBASE_AUTH_DOMAIN, databaseURL: process.env.VUE_APP_FIREBASE_DATABASE_URL, projectId: process.env.VUE_APP_FIREBASE_PROJECT_ID, storageBucket: process.env.VUE_APP_FIREBASE_STORAGE_BUCKET, messagingSenderId: process.env.VUE_APP_FIREBASE_MESSAGING_SENDER_ID, appId: process.env.VUE_APP_FIREBASE_APP_ID }; firebase.initializeApp(firebaseConfig); const db = firebase.firestore(); export default db;
最后,在src/main.js
文件中集成Vue和Firebase:
import Vue from 'vue'; import App from './App.vue'; import router from './router'; Vue.config.productionTip = false; new Vue({ router, render: (h) => h(App) }).$mount('#app');
六、运行应用
在终端中执行以下命令,运行应用:
npm run serve
访问http://localhost:8080
rrreee
Remplacez YOUR_API_KEY
, YOUR_AUTH_DOMAIN
, etc. avec les valeurs réelles que vous obtenez dans la console Firebase.
3. Créer des composants Vue
- NewsList.vue rrreee
- NewNews.vue rrreee
src/router/index.js
: 🎜rrreee🎜 Définissez le style de base dans le fichier src/App.vue
: 🎜rrreee🎜 5. Intégrez les applications Firebase et Vue 🎜Configurez Firebase dans le fichier src/firebaseConfig.js
: 🎜 rrreee 🎜Enfin, intégrez Vue et Firebase dans le fichier src/main.js
: 🎜rrreee🎜 6. Exécutez l'application 🎜Exécutez la commande suivante dans le terminal pour exécuter l'application : 🎜rrreee🎜Visitez http: //localhost:8080, vous verrez une application de newsletter avec fonction de synchronisation des données en temps réel. 🎜🎜Résumé : 🎜Cet article explique comment utiliser Vue.js et Firebase Cloud Firestore pour implémenter une application de newsletter avec synchronisation des données en temps réel. Nous avons créé deux composants Vue pour afficher la liste des actualités et publier des actualités, puis configuré le routage et les styles. Enfin, nous utilisons Firebase pour stocker et synchroniser les données et les intégrer dans l'application Vue. Avec ces étapes, nous pouvons facilement créer une application de newsletter avec des capacités de synchronisation en temps réel. 🎜🎜Matériaux de référence : 🎜🎜🎜Documentation officielle de Vue.js : https://vuejs.org/🎜🎜Documentation officielle de Firebase : https://firebase.google.com/docs🎜🎜Documentation officielle de Vue CLI : https:// cli.vuejs.org/🎜🎜Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Vous pouvez ajouter une fonction au bouton VUE en liant le bouton dans le modèle HTML à une méthode. Définissez la logique de la fonction de méthode et d'écriture dans l'instance Vue.

L'utilisation de bootstrap dans vue.js est divisée en cinq étapes: installer bootstrap. Importer un bootstrap dans main.js. Utilisez le composant bootstrap directement dans le modèle. Facultatif: style personnalisé. Facultatif: utilisez des plug-ins.

Il existe trois façons de se référer aux fichiers JS dans Vue.js: spécifiez directement le chemin à l'aide du & lt; script & gt; étiqueter;; importation dynamique à l'aide du crochet de cycle de vie monté (); et l'importation via la bibliothèque de gestion de l'État Vuex.

L'option Watch dans Vue.js permet aux développeurs d'écouter des modifications de données spécifiques. Lorsque les données changent, regardez déclenche une fonction de rappel pour effectuer des vues de mise à jour ou d'autres tâches. Ses options de configuration incluent immédiatement, qui spécifie s'il faut exécuter un rappel immédiatement, et profond, ce qui spécifie s'il faut écouter récursivement les modifications des objets ou des tableaux.

Vue.js dispose de quatre méthodes pour revenir à la page précédente: $ router.go (-1) $ router.back () utilise & lt; router-link to = & quot; / & quot; Composant Window.History.back (), et la sélection de la méthode dépend de la scène.

Le développement multi-pages VUE est un moyen de créer des applications à l'aide du cadre Vue.js, où l'application est divisée en pages distinctes: Maintenance du code: La division de l'application en plusieurs pages peut rendre le code plus facile à gérer et à maintenir. Modularité: chaque page peut être utilisée comme module séparé pour une réutilisation et un remplacement faciles. Routage simple: la navigation entre les pages peut être gérée par une configuration de routage simple. Optimisation du référencement: chaque page a sa propre URL, ce qui aide le référencement.

Il existe deux façons de sauter des éléments div dans Vue: Utilisez le routeur Vue et ajoutez le composant routeur-link. Ajoutez l'écouteur de l'événement @Click et appelez ceci. $ Router.push () pour sauter.

Il existe trois méthodes courantes pour que Vue.js traverse les tableaux et les objets: la directive V-FOR est utilisée pour traverser chaque élément et les modèles de rendu; La directive V-Bind peut être utilisée avec V-FOR pour définir dynamiquement les valeurs d'attribut pour chaque élément; et la méthode .map peut convertir les éléments du tableau en nouveaux tableaux.
