亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

Table des matières
3. Créez une classe de service de panier
4. Créer un contr?leur de chariot
5. Définir les routes
6. Exemple de modèle de lame
7. Sync Cart sur la connexion (facultatif mais recommandé)
Notes finales
Maison cadre php Laravel Comment mettre en ?uvre un panier à Laravel?

Comment mettre en ?uvre un panier à Laravel?

Jul 29, 2025 am 03:40 AM

Utilisez la session pour stocker les paniers d'achat de visiteurs et les magasins de base de données connectés aux paniers d'achat utilisateur pour la persistance; 2. Créez des tables de panier pour stocker les données de panier d'achat utilisateur; 3. Créez une classe de service CartService pour encapsuler l'addition, la suppression, la modification et la logique de recherche; 4. Créer un contr?leur CartController pour gérer les opérations de panier d'achat; 5. Définir les routes dans web.php; 6. Créer un modèle de lame pour afficher le contenu du panier d'achat; 7. Faire fusionner les paniers d'achat de session dans la base de données lorsque l'utilisateur se connecte. Cette solution met en ?uvre un système de panier hybride qui prend en charge les visiteurs et les utilisateurs certifiés, et est durable, évolutif et répond aux besoins pratiques d'application.

Comment mettre en ?uvre un panier à Laravel?

La mise en ?uvre d'un panier à Laravel peut être effectuée de plusieurs manières en fonction de vos besoins - basée sur les utilisateurs invités, soutenu par la base de données pour les chariots persistants ou l'utilisation d'un package comme gloudemans/shoppingcart (maintenant archivé, mais toujours utilisé). Vous trouverez ci-dessous un guide pratique pour construire un système de panier simple mais efficace à partir de zéro.

Comment mettre en ?uvre un panier à Laravel?

1. Décider du stockage du chariot: Session vs base de données

Pour la plupart des applications Laravel, vous voudrez prendre en charge les invités et les utilisateurs connectés :

  • Invités : Chariot de magasin dans la session.
  • Utilisateurs connectés : stocker le panier dans la base de données, synchronisé avec la session pour la cohérence.

Cette approche hybride donne de la flexibilité et de la persistance.

Comment mettre en ?uvre un panier à Laravel?

2. Configuration de la base de données (pour les utilisateurs authentifiés)

Si vous voulez des chariots persistants, créez une table cart :

 PHP Artisan Make: Migration Create_Cart_Table
 Schéma :: Create ('CART', fonction (Table Blueprint $) {
    $ table-> id ();
    $ Table-> ForeignId ('user_id') -> contrainte () -> ondelete ('cascade');
    $ Table-> ForeignId ('product_id') -> contrainte ();
    $ table-> entier ('quantité') -> par défaut (1);
    $ Table-> TimeStamps ();
});

Exécuter la migration:

Comment mettre en ?uvre un panier à Laravel?
 PHP Artisan Migrate

3. Créez une classe de service de panier

Au lieu de mettre la logique dans les contr?leurs, créez un service réutilisable:

 PHP Artisan Make: Service CartService

Dans app/Services/CartService.php :

 Namespace App \ Services;

Utiliser illuminate \ support \ FACADES \ Auth;
Utiliser illuminate \ support \ FACADES \ Session;
Utilisez App \ Models \ CART;
Utilisez App \ Models \ Product;

classe de classe
{
    fonction publique get ()
    {
        if (auth :: check ()) {
            return Cart :: with ('product') -> où ('user_id', auth :: id ()) -> get ();
        }

        Session de retour :: get ('cart', []);
    }

    fonction publique ajouter ($ productId, $ quantité = 1)
    {
        $ Product = Product :: FindorFail ($ productId);

        if (auth :: check ()) {
            $ Cartitem = Cart :: Firstornw ([
                'user_id' => auth :: id (),
                'product_id' => $ product-> id,
            ]));

            $ cartitem-> quantité = $ quantité;
            $ Cartitem-> SAVE ();
        } autre {
            $ cart = session :: get ('cart', []);
            if (isset ($ cart [$ productid])) {
                $ Cart [$ productId] ['Quantité'] = $ Quantité;
            } autre {
                $ cart [$ productid] = [
                    'product_id' => $ product-> id,
                    'name' => $ product-> name,
                    'Price' => $ Product-> Prix,
                    'quantité' => $ quantité,
                ]]
            }
            Session :: put (?Cart?, $ cart);
        }
    }

    Mise à jour de la fonction publique ($ productId, $ Quantity)
    {
        if (auth :: check ()) {
            $ carcitem = Cart :: Where ('user_id', auth :: id ())
                           -> où ('product_id', $ productId)
                           -> First ();
            if ($ carditem) {
                if ($ quantité <= 0) {
                    $ cartitem-> delete ();
                } autre {
                    $ cartitem-> quantité = $ quantité;
                    $ Cartitem-> SAVE ();
                }
            }
        } autre {
            $ cart = session :: get (&#39;cart&#39;, []);
            if (isset ($ cart [$ productid])) {
                if ($ quantité <= 0) {
                    Unset ($ CART [$ productId]);
                } autre {
                    $ Cart [$ productId] [&#39;Quantité&#39;] = $ Quantité;
                }
                Session :: put (?Cart?, $ cart);
            }
        }
    }

    Fonction publique Supprimer ($ productId)
    {
        $ this-> mise à jour ($ productId, 0);
    }

    Fonction publique Clear ()
    {
        if (auth :: check ()) {
            Cart :: où (&#39;user_id&#39;, auth :: id ()) -> delete ();
        } autre {
            Session :: oublier (&#39;CART&#39;);
        }
    }

    fonction publique total ()
    {
        $ cart = $ this-> get ();
        if (auth :: check ()) {
            return $ cart-> sum (fn ($ item) => $ item-> product-> prix * $ item-> quantité);
        } autre {
            return Collect ($ cart) -> sum (fn ($ item) => $ item [&#39;prix&#39;] * $ item [&#39;Quantity&#39;]);
        }
    }
}

Assurez-vous que votre modèle Product est configuré et dispose d'un champ price .


4. Créer un contr?leur de chariot

 PHP Artisan Make: Contr?leur de contr?leur
 Namespace App \ Http \ Controllers;

Utiliser App \ Services \ CartService;
Utiliser illuminate \ http \ request;

Class CartController étend le contr?leur
{
    protégé $ cartservice;

    Fonction publique __construct (cartservice $ cartservice)
    {
        $ this-> cartService = $ cartService;
    }

    Index de fonction publique ()
    {
        $ carcitems = $ this-> cartService-> get ();
        $ total = $ this-> cartService-> total ();

        Return View (&#39;Cart.Index&#39;, compact (&#39;Cartitems&#39;, &#39;Total&#39;));
    }

    fonction publique ajouter (demande $ demande)
    {
        $ this-> cartService-> add ($ request-> id, $ request-> quantité ?? 1);

        return redirect () -> back () -> avec (&#39;succès&#39;, &#39;item ajouté à cart!&#39;);
    }

    Mise à jour de la fonction publique (demande $ demande, $ id)
    {
        $ this-> CartService-> Update ($ id, $ request-> quantité);

        return redirect () -> Route (&#39;Cart.index&#39;);
    }

    Suppression de la fonction publique ($ id)
    {
        $ this-> CartService-> retirer ($ id);

        return redirect () -> Route (&#39;Cart.index&#39;);
    }

    Fonction publique Clear ()
    {
        $ this-> cartService-> clear ();

        return redirect () -> Route (&#39;Cart.index&#39;);
    }
}

5. Définir les routes

Dans routes/web.php :

 Utilisez App \ Http \ Controllers \ CartController;

Route :: Middleware ([&#39;Auth&#39;]) -> Groupe (fonction () {
    Route :: get (&#39;/ cart&#39;, [cartController :: class, &#39;index&#39;]) -> name (&#39;Cart.index&#39;);
    Route :: Post (&#39;/ Cart / add / {id}&#39;, [CartController :: class, &#39;add&#39;]) -> name (&#39;cart.add&#39;);
    Route :: put (&#39;/ carta / update / {id}&#39;, [cartController :: class, &#39;update&#39;]) -> name (&#39;Cart.update&#39;);
    Route :: Delete (&#39;/ Cart / REPOP / {id}&#39;, [CartController :: class, &#39;repos&#39;]) -> name (&#39;cart.remove&#39;);
    Route :: Delete (&#39;/ Cart / Clear&#39;, [CartController :: Class, &#39;Clear&#39;]) -> name (&#39;Cart.Clear&#39;);
});

Vous pouvez autoriser add sans auth si vous souhaitez que les invités ajoutent des articles.


6. Exemple de modèle de lame

resources/views/cart/index.blade.php :

 <h1> Votre panier </h1>

@if (session (?succès?))
    <div class = "alert-alert-sucess"> {{session (&#39;succès&#39;)}} </div>
@endif

<ul>
    @ForEach ($ Cartitems As $ article)
        <li>
            {{$ item [&#39;name&#39;] ?? $ item-> Product-> nom}}
            x {{$ item [&#39;quantité&#39;] ?? $ item-> quantité}}
            = $ {{($ item [&#39;Price&#39;] ?? $ item-> Product-> prix) * ($ item [&#39;Quantity&#39;] ?? $ item-> quantité)}}

            <form méthode = "post" Action = "{{Route (&#39;Cart.Update&#39;, $ item [&#39;product_id&#39;] ?? $ item-> product_id)}}" style = "affiche: inline;">
                @csrf
                @Method (&#39;put&#39;)
                <input type = "nombre" name = "quantité" value = "{{$ item [&#39;Quantity&#39;] ?? $ item-> quantité}}" min = "1" />
                <Button Type = "Soumider"> Mise à jour </frutch>
            </ form>

            <form méthode = "post" action = "{{Route (&#39;Cart.remove&#39;, $ item [&#39;product_id&#39;] ?? $ item-> product_id)}}" style = "affiche: inline;">
                @csrf
                @Method (&#39;Delete&#39;)
                <Button Type = "Soumider"> Supprimez </fontificateur>
            </ form>
        </li>
    @endforeach
</ul>

<p> <strong> total: $ {{numéro_format ($ total, 2)}} </strong> </p>
<a href = "{{Route (&#39;Checkout&#39;)}}"> Procéder à la caisse </a>

7. Sync Cart sur la connexion (facultatif mais recommandé)

Lorsqu'un utilisateur se connecte, fusionnez le panier de session dans la base de données.

Dans votre LoginController ou utilisez un écouteur d'événements:

 // dans une méthode authentifiée de connexion LoginController ou d&#39;utilisation
fonction publique authentifiée (demande $ demande, $ utilisateur)
{
    // fusionner le panier de session dans la base de données
    $ sessioncart = session :: get (&#39;cart&#39;, []);
    foreach ($ sessioncart comme $ item) {
        $ Cartitem = Cart :: Firstornw ([
            &#39;user_id&#39; => $ user-> id,
            &#39;product_id&#39; => $ item [&#39;product_id&#39;],
        ]));
        $ carcitem-> quantité = $ item [&#39;quantité&#39;];
        $ Cartitem-> SAVE ();
    }

    Session :: oublier (&#39;CART&#39;); // chariot de session claire
}

Notes finales

  • Vous pouvez améliorer cela avec Ajax pour UX plus lisse.
  • Pensez à utiliser Laravel Livewire pour les mises à jour de CART en temps réel.
  • Pour les applications à grande échelle, envisagez d'utiliser Redis ou un microservice de panier dédié.

Fondamentalement, vous avez maintenant un système de panier flexible qui fonctionne à la fois pour les invités et les utilisateurs connectés, persiste les données et est facile à étendre. Pas trop complexe, mais couvre les besoins réels.

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefa?on, veuillez contacter admin@php.cn

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Création de règles de validation personnalisées dans un projet Laravel Création de règles de validation personnalisées dans un projet Laravel Jul 04, 2025 am 01:03 AM

Il existe trois fa?ons d'ajouter des règles de validation personnalisées dans Laravel: en utilisant les fermetures, les classes de règles et les demandes de formulaire. 1. Utilisez les fermetures pour être adaptées à la vérification légère, comme empêcher le nom d'utilisateur "admin"; 2. Créez des classes de règles (telles que ValidUsernamerule) pour rendre la logique complexe plus claire et maintenable; 3. Intégrer plusieurs règles dans les demandes de formulaire et gérer de manière centralisée la logique de vérification. Dans le même temps, vous pouvez définir des invites via des méthodes de messages personnalisés ou des réseaux de messages d'erreur entrants pour améliorer la flexibilité et la maintenabilité.

Ajout d'un support multilingue à une application Laravel Ajout d'un support multilingue à une application Laravel Jul 03, 2025 am 01:17 AM

Les méthodes de base pour les applications Laravel pour implémenter le support multilingue comprennent: la définition des fichiers linguistiques, la commutation de langage dynamique, le routage des URL de traduction et la gestion des clés de traduction dans les modèles de lame. Tout d'abord, organisez les cha?nes de chaque langue dans les dossiers correspondants (tels que EN, ES, FR) dans le répertoire / Resources / Lang, et définissez le contenu de traduction en renvoyant le tableau associatif; 2. Traduire la valeur de clé via l'appel de fonction d'assistance \ _ \ _ () et utilisez l'application :: setLocale () pour combiner des paramètres de session ou de routage pour réaliser la commutation du langage; 3. Pour les URL de traduction, les chemins peuvent être définis pour différentes langues via des groupes de routage préfixés ou par voie d'alias dans les fichiers linguistiques mappés dynamiquement; 4. Gardez les touches de traduction concises et

Travailler avec des tables de pivot dans Laravel plusieurs à plusieurs relations Travailler avec des tables de pivot dans Laravel plusieurs à plusieurs relations Jul 07, 2025 am 01:06 AM

TOWORKEFFECTECTEMENTSWitHPivottablesInLaravel, FirstAccessPivotDatauSingWithPivot () Orwithtimestamps (), ThepDateEntrieswitHupDateExistPivot (), ManagerLeshipSviaDeTache

Envoi différents types de notifications avec Laravel Envoi différents types de notifications avec Laravel Jul 06, 2025 am 12:52 AM

LaravelprovidesAcleanAndFlexiblewayToSendNotificationsViamultipleChannelsLikeEmail, SMS, In-Appakets, andpushNotifications.youdefinenotificationChannelsInthevia () MethodofanotificationClass, ANDIDEFINENOTIFICATIONSECHETHODSLIKETOMAIL (), ToDatabase (), Ortovonage

Comprendre et créer des fournisseurs de services personnalisés à Laravel Comprendre et créer des fournisseurs de services personnalisés à Laravel Jul 03, 2025 am 01:35 AM

ServiceProvider est le mécanisme de base utilisé dans le cadre Laravel pour l'enregistrement des services et l'initialisation de la logique. Vous pouvez créer un ServiceProvider personnalisé via la commande Artisan; 1. La méthode de registre est utilisée pour lier les services, enregistrer des singletons, définir des alias, etc., et d'autres services qui n'ont pas encore été chargés ne peuvent pas être appelés; 2. La méthode de démarrage s'exécute après que tous les services sont enregistrés et sont utilisés pour enregistrer les écouteurs d'événements, afficher les synthétiseurs, middleware et autres logiques qui dépend d'autres services; Les utilisations courantes incluent les interfaces et les implémentations de liaison, l'enregistrement des fa?ades, le chargement des configurations, l'enregistrement des instructions de ligne de commande et des composants de vue; Il est recommandé de centraliser les liaisons pertinentes à un ServiceProvider pour gérer et de faire attention à l'enregistrement

Comprendre l'injection de dépendance à Laravel? Comprendre l'injection de dépendance à Laravel? Jul 05, 2025 am 02:01 AM

L'injection de dépendance gère automatiquement les dépendances de classe via des conteneurs de service dans Laravel sans de nouveaux objets manuels. Son noyau est l'injection de constructeur et l'injection de méthode, comme le passage automatiquement de l'instance de demande dans le contr?leur. Laravel analyse les dépendances via des invites de type et crée récursivement les objets requis. L'interface de liaison et l'implémentation peuvent être utilisées par le fournisseur de services pour utiliser la méthode Bind, ou singleton pour lier un singleton. Lorsque vous l'utilisez, vous devez vous assurer des invites de type, éviter les complications du constructeur, utiliser les liaisons contextuelles avec prudence et comprendre les règles d'analyse automatique. La ma?trise peut améliorer la flexibilité et la maintenance du code.

Gestion des exceptions et des erreurs de journalisation dans une application Laravel Gestion des exceptions et des erreurs de journalisation dans une application Laravel Jul 02, 2025 pm 03:24 PM

Les méthodes de base pour gérer les exceptions et les erreurs d'enregistrement dans les applications Laravel incluent: 1. Utilisez la classe App \ Exceptions \ Handler pour gérer de manière centralisée les exceptions non gérées, et enregistrer ou notifier les informations d'exception via la méthode Report (), telles que l'envoi de notifications Slack; 2. Utilisez Monolog pour configurer le système de journal, définissez le niveau de journal et la méthode de sortie dans config / logging.php et activer les journaux d'erreur et supérieurs à l'environnement de production. Dans le même temps, des informations d'exception détaillées peuvent être enregistrées manuellement dans report () en combinaison avec le contexte; 3. Personnalisez la méthode Render () pour retourner une réponse d'erreur de format JSON unifié, améliorant l'efficacité de collaboration de l'extrémité avant et arrière de l'API. Ces étapes sont

Stratégies pour optimiser les performances de l'application Laravel Stratégies pour optimiser les performances de l'application Laravel Jul 09, 2025 am 03:00 AM

L'optimisation des performances de Laravel peut améliorer l'efficacité de l'application à travers quatre directions de base. 1. Utilisez le mécanisme de cache pour réduire les requêtes en double, stocker rarement la modification des données via Cache :: Remember () et d'autres méthodes pour réduire la fréquence d'accès à la base de données; 2. Optimiser la base de données de la requête du modèle aux requêtes, évitez les requêtes N 1, spécifiant les requêtes de champ, ajoutant des index, pagination de traitement et de lecture et de séparation d'écriture et réduire les goulots d'étranglement; 3. Utilisez des opérations longues telles que l'envoi d'e-mails et l'exportation de fichiers vers le traitement asynchrone de file d'attente, utilisez le superviseur pour gérer les travailleurs et configurer des mécanismes de réessayer; 4. Utilisez raisonnablement les fournisseurs de middleware et de services pour éviter une logique complexe et un code d'initialisation inutile et retarder le chargement des services pour améliorer l'efficacité du démarrage.

See all articles