


Comment utiliser Vue pour implémenter la fonction Ajouter un ami
Avec l'essor des médias sociaux, l'ajout d'amis est devenu un élément indispensable des interactions quotidiennes des gens. Pour les développeurs front-end, comment implémenter la fonction d'ajout d'amis sur la page est une question qui mérite réflexion. Cet article expliquera comment utiliser le framework Vue pour implémenter la fonction d'ajout d'un ami.
1. Connaissances préalables
Avant de commencer à introduire la fonction d'ajout d'amis, nous devons connaître les éléments suivants :
- Créer un projet à l'aide de Vue CLI
- Concepts de base et utilisation des composants Vue ; et les composants enfants Méthode ;
- Concepts de base et utilisation de Vue Router.
- 2. Concevoir la page
Lors de la conception de la page pour ajouter des amis, nous devons prendre en compte la mise en page et les fonctionnalités de la page. Habituellement, la fonction d'ajout d'un ami doit inclure le contenu suivant :
Zone de recherche : les utilisateurs peuvent saisir le nom ou l'identifiant de l'ami dans la zone de recherche pour effectuer une recherche ;- Liste des utilisateurs : afficher la liste des utilisateurs en fonction des résultats de la recherche ; Bouton Ajouter un ami : les utilisateurs peuvent envoyer des demandes d'ami aux utilisateurs dans les résultats de recherche en cliquant sur le bouton Ajouter un ami.
- Sur la base du contenu ci-dessus, nous pouvons concevoir la mise en page suivante :
<template> <div class="friend-add"> <!-- 搜索框部分 --> <div class="search-bar"> <input type="text" placeholder="请输入好友名字或ID" v-model="keyword"> <button @click="search">搜索</button> </div> <!-- 用户列表部分 --> <div class="user-list"> <ul> <li v-for="(user, index) in userList" :key="index"> {{ user.name }} <button @click="addFriend(user)">添加好友</button> </li> </ul> </div> </div> </template>
Obtenir la liste des utilisateurs
- Une fois que l'utilisateur a saisi le mot-clé dans le champ de recherche, nous devons demander via l'interface d'obtenir la liste des utilisateurs qui répondent aux conditions de recherche. Dans Vue, nous encapsulons généralement cette fonction dans un composant :
<template> <div class="user-list"> <ul> <li v-for="(user, index) in userList" :key="index">{{ user.name }}</li> </ul> </div> </template> <script> export default { data() { return { userList: [] } }, methods: { getUserList() { // TODO: 发送接口请求,获取用户列表 this.userList = [ { name: '张三', id: 1 }, { name: '李四', id: 2 }, { name: '王五', id: 3 }, ] } }, mounted() { this.getUserList() } } </script>
Les composants parent-enfant transmettent des valeurs
- Dans Vue, les composants parents transmettent des données aux composants enfants, ce qui peut être obtenu via des accessoires. Nous pouvons transmettre les mots-clés saisis par l'utilisateur dans le champ de recherche au sous-composant via des accessoires, afin que le sous-composant puisse effectuer une recherche en fonction des mots-clés de recherche lors de l'envoi d'une demande.
<template> <div class="friend-add"> <div class="search-bar"> <!-- 在搜索框中添加v-model指令,将输入框中的值与父组件的keyword进行双向绑定 --> <input type="text" placeholder="请输入好友名字或ID" v-model="keyword"> <button @click="search">搜索</button> </div> <user-list :keyword="keyword"></user-list> </div> </template> <script> import UserList from './UserList' export default { components: { UserList }, data() { return { keyword: '' } }, methods: { search() { // 点击搜索按钮时触发该函数,这里的search功能可以自行实现 this.$refs.userList.getUserList() } } } </script>
<template> <div class="user-list"> <ul> <li v-for="(user, index) in userList" :key="index"> {{ user.name }} <button @click="addFriend(user)">添加好友</button> </li> </ul> </div> </template> <script> export default { props: { keyword: String }, data() { return { userList: [] } }, methods: { getUserList() { // TODO:根据this.keyword向后端发送请求,获取用户列表 }, addFriend(user) { // TODO:向后端发送请求,添加好友 } } } </script>
Vue Router
- Lors de la mise en œuvre de la fonction d'ajout d'amis, nous devons généralement prendre en compte le problème de saut de page après que l'utilisateur a ajouté un ami. Afin de mieux implémenter la fonction de saut de page, nous devons utiliser Vue Router.
vue create my-project
<template> <div> <!-- 用户列表部分 --> <div class="user-list"> <ul> <li v-for="(user, index) in userList" :key="index"> {{ user.name }} <button @click="addFriend(user)">添加好友</button> </li> </ul> </div> </div> </template> <script> import { mapState } from 'vuex' export default { data() { return { userList: [] } }, computed: { ...mapState(['userInfo']) }, methods: { async addFriend(user) { // 向后端发送请求,添加好友 await this.$http.post('/add-friend', {id: user.id}) // 添加好友成功之后,跳转到好友详情页面 this.$router.push({ name: 'friendDetail', params: { friendId: user.id } }) } } } </script>
import Vue from 'vue' import VueRouter from 'vue-router' import FriendDetail from '@/views/FriendDetail.vue' Vue.use(VueRouter) const routes = [ { path: '/friend-detail/:friendId', name: 'friendDetail', component: FriendDetail } ] const router = new VueRouter({ mode: 'history', base: process.env.BASE_URL, routes }) export default router
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)

L'article traite de l'utilisation Effecte dans React, un crochet pour gérer les effets secondaires comme la récupération des données et la manipulation DOM dans les composants fonctionnels. Il explique l'utilisation, les effets secondaires courants et le nettoyage pour éviter des problèmes comme les fuites de mémoire.

Le chargement paresseux retarde le chargement du contenu jusqu'à ce qu'il soit nécessaire, améliorant les performances du Web et l'expérience utilisateur en réduisant les temps de chargement initiaux et la charge du serveur.

L'article explique l'algorithme de réconciliation de React, qui met à jour efficacement le DOM en comparant les arbres DOM virtuels. Il traite des avantages de la performance, des techniques d'optimisation et des impacts sur l'expérience utilisateur. Compte de charge: 159

L'article traite du curry dans JavaScript, une technique transformant les fonctions mulguments en séquences de fonctions à argument unique. Il explore la mise en œuvre du currying, des avantages tels que des applications partielles et des utilisations pratiques, améliorant le code

Les fonctions d'ordre supérieur dans JavaScript améliorent la concision du code, la réutilisabilité, la modularité et les performances par abstraction, modèles communs et techniques d'optimisation.

L'article explique UseContext dans React, qui simplifie la gestion de l'État en évitant le forage des accessoires. Il traite des avantages tels que les améliorations centralisées de l'État et des performances grâce à des redevances réduites.

L'article discute de la connexion des composants React à Redux Store à l'aide de Connect (), expliquant MapStateToproprop, MapDispatchToprops et des impacts de performances.

L'article discute de la prévention des comportements par défaut dans les gestionnaires d'événements à l'aide de la méthode empêchée dedEfault (), de ses avantages tels que une expérience utilisateur améliorée et des problèmes potentiels tels que les problèmes d'accessibilité.
