Firestore fournit un moyen puissant d'interroger des données à l'aide d'opérateurs tels que "==" et "!=". Lorsqu'il s'agit de filtres dynamiques, il devient nécessaire d'appliquer conditionnellement des clauses Where basées sur les entrées de l'utilisateur.
Considérez le scénario dans lequel vous disposez d'une liste de livres avec des attributs tels que la couleur, l'auteur et la catégorie. Vous souhaitez permettre aux utilisateurs de filtrer les livres en fonction de plusieurs sélections de couleurs et de catégories. Voyons comment implémenter cela à l'aide des clauses Where de Firestore.
<code class="javascript">// Assume you have dynamic filters captured as arrays const colors = ["Red", "Blue"]; const categories = ["Adventure", "Detective"]; // Create the base query var query = firebase.firestore().collection("book"); // Loop through the dynamic filters and add where clauses if (colors.length > 0) { query = query.where("color", "in", colors); } if (categories.length > 0) { query = query.where("category", "in", categories); } // Add ordering logic query = query.orderBy("date"); // Execute the query query.get().then((querySnapshot) => {...});</code>
Dans l'exemple ci-dessus, nous établissons d'abord la requête de base. Ensuite, nous ajoutons conditionnellement des clauses Where en fonction de la présence de filtres sélectionnés par l'utilisateur. Enfin, nous appliquons le classement et exécutons la requête.
Cette approche vous permet d'appliquer dynamiquement plusieurs clauses Where, la rendant flexible et adaptable aux préférences changeantes de l'utilisateur. Gardez à l'esprit que vous devez vous assurer de gérer les filtres vides pour éviter les requêtes inutiles.
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!