Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Navigation à facettes


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Navigation à facettes
    Bonjour,

    Actuellement, je conçois un site pour un membre de famille pour sa micro-entreprise. Je me débrouille comme je peux avec mes connaissances et en allant sur le net mais là, je dois faire face à une demande qui me bloque complètement.

    Tout d'abord, je pense que cette demande doit se faire en php (et sans doute avec une base de données) et malheureusement, mis à part bidouiller du code déjà conçu, je ne peux pas partir de rien.

    Bref, l'idée est de proposer un pc pré-monté selon les choix qu'aura effectuer l'utilisateur via le formulaire du site. J'ai pensé qu'il faudrait un système de filtrage un peu comme sur les site d'e-commerce quand on recherche un type de produit avec différents critères.

    Apparemment, cela se nomme la navigation à facettes mais mes recherches m'amène à de l'optimisation, du SEO, ... Mais pas de quoi au moins débuter.

    Pouvez-vous m'aider ?

    JE vous remercie d'avance.

  2. #2
    Modérateur

    Si je comprend bien le besoin , ton but final c'est grosso modo un moteur de recherche qui va te retourner une config PC en fonction de certains critère ?

    L'idéal pour faire celà c'est effectivement une base de donnée mais ce n'est pas l'unique solution.

    Cette base données peut tout à fait être représenté sous forme d'un fichier de type texte (csv,json,etc) tant que la quantité de données n'est pas trop importante (sinon le traitement risque d'être long).

    La réalisation peut se faire soit en PHP soit en javascript au choix.

    Mais le principe est le suivant :

    - Réaliser le formulaire de recherche
    - Récupérer les paramètres du formulaire
    - Rechercher dans la source de données (base de données, fichier texte, etc ...) les résultats correspondants
    - Retourner et afficher ces résutats.
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Futur Membre du Club
    Oui c'est tout à fait ça. Il y aura 4 critères obligatoires qui retourneront un ou plusieurs résultats (avec les informations nécessaires) suivant les paramètres indiqués par l'utilisateur avec en plus, un choix de périphériques optionnel.

    J'ai continué à réfléchir à la question et la navigation à facettes ne semble pas pertinent car il n'y aura pas 50 pc proposés, tout au plus une dizaine voir une douzaine donc j'ai songé à un formulaire plus simple par case radio (et checkbox pour les périphérique). Donc, ça semble se rapprocher de ton idée sauf pour la bdd, je ne savais pas qu'on pouvait passer par un fichier.

    Je vais essayé de trouver des tutoriels car je ne connais pas grand chose en php^^

  4. #4
    Membre du Club
    Salut,

    Alors j'ai vu ce qu'on appelle la navigation à facette, il y a un exemple ici:
    https://www.definitions-marketing.com/definition/navigation-a-facettes/

    De ce que je vois sur l'aspect technique, ça peut être fait en ajax si tu veux un rendu sans rechargement, sinon tu peux tout autant recharger la page en traitant ton formulaire quand un critère est sélectionné (peut être plus simple si tu débutes, mais ajax te servira si tu comptes continuer).

    En gros à chaque changement de paramètre une requête de recherche avec les résultats pour la combinaison en cours est envoyé, et dans le même temps les critères de recherche sont adaptés selon les filtres déjà actifs. En structurant bien sa base de données (notamment gestion des clés échangées entre les tables) cela ne doit pas être extrêmement compliqué, mais ça se réfléchit (même si je pense que tu peux trouver des exemples tout fait).

    Pour ta problématique, un système de formulaire avec boutons radios et checkboxes fera largement l'affaire et te simplifiera la vie, tu affiches le résultat quand l'utilisateur a fini de saisir ses critères et c'est réglé.

    Comme il te l'a été dit, tu peux tout autant traiter les données par fichier (pense éventuellement à une modélisation XML avec un parser PHP derrière ça te simplifiera les choses plutôt que de balayer les blocs textuels non structuré).
    Cependant, pour tes propres connaissances et par soucis de pérennité, j'opterais plus pour une solution BDD, MySql ou MariaDB (même chose techniquement) sont assez simples à mettre en oeuvre et très puissant.
    A titre personnel, même pour mes applications de bureau en C# dès que je dois gérer un fichier j'utilise systématiquement une BDD (SQLite ici), une fois qu'on connait SQL, c'est beaucoup
    plus confortable d'utiliser ça pour accéder à ses éléments, faire des recherches complexes etc. que de fouiner dans un fichier texte. Mais ce n'est que mon avis.

  5. #5
    Futur Membre du Club
    tevious > je suis effectivement partie sur les boutons radios et une base de données MySQL. Pour l'instant, j'ai créé la table ainsi que le visuel de la page de recherche.

    Pour le reste, j'essaye de me renseigner sur le net, de trouver des tutos mais je t'avoue que ça me dépasse.

  6. #6
    Membre du Club
    C'est un bon départ, personnellement je déteste le webdesign, j'utilise autant que possible des kits CSS...

    Tu es dépassé à quel niveau? Si c'est le php, selon tes connaissances préalables ça peut aller très vite (il y a 10 ans quand je débutais en info je galérais à comprendre), depuis mes connaissances dans d'autres langages j'ai mis 2 jours à le maitriser suffisamment pour pouvoir pondre un site.

    Là où il faut que tu fasses particulièrement attention ce sera au niveau de ta base de données, si je comprends bien tu veux pouvoir gérer des commandes, donc il faut bien structurer tes tables pour que ça ne soit pas bordélique.
    Si tu ne connais rien en SQL c'est l'occasion d'apprendre, notamment les fameuses jointures entre tables et compagnie, ça peut être rebutant au début, mais c'est super intéressant derrière.

    Si tu veux je peux te filer un coup de main pour un peu tout ça, j'aime bien toute la partie backend et comme j'ai pas de projet spécifique en ce moment côté perso, ça me donnera une occupation.

###raw>template_hook.ano_emploi###