آموزش ساخت فروشگاه اینترنتی با لاراول و Snipcart + دمو

زمان مطالعه 12 دقیقه
آموزش ساخت فروشگاه اینترنتی با لاراول و Snipcart + دمو

در این مقاله به آموزش ساخت فروشگاه اینترنتی با لاراول و توضیحات این فرمورک دوست داشتنی پرداخته شده که ساخت پروژه های فول استک و مقیاس پذیر را از همان ابتدا برای شما آسان می کند!

0
(0)

PHP از برخی جهات ستون فقرات اینترنت محسوب می شود! اینطور که در هسته وردپرس قرار دارد و البته آمار فوق العاده استفاده 39.9 درصد از تمام وب سایت های امروزی را در اختیار دارد. توسط بزرگترین رسانه های اجتماعی همچون فیس بوک استفاده می شود. امیدواریم این آموزش ساخت فروشگاه اینترنتی با لاراول ، به شما در مسیر یادگیریتان کمک کند تا بتوانید مسیر طراحی سایت لاراول ی خود را سریعتر و با موفقیت طی کنید.

نگاهی سریع به طراحی فروشگاه اینترنتی با لاراول !

فرمورک لاراول یک چارچوب وب PHP اپن سورس است که برای طراحی وب سایت با php و برنامه های وب آن استفاده می شود، منحنی یادگیری نرمی داشته و برخی از ویژگی‌های عجیب و غریب ساختن با PHP را حذف می‌کند. برخی معتقدند که این معادل Ruby on Rails PHP می باشد.

می توانید از Composer برای مدیریت وابستگی ها و پکیج ها در لاراول استفاده کنید. بسیاری از پکیج های مفید به شما امکان می دهند توسعه لاراول خود را سریعتر کنید. به مواردی مانند اشکال زدایی، احراز هویت، تعاملات API و غیره فکر کنید. سایت هایی مانند Packagist و Packalyst منابع عالی برای یافتن پکیج های مفید لاراول هستند.

از سپتامبر 2020 ، لاراول 8 در دسترس عموم قرار داشته و ویژگی‌هایی مانند لاراول جت استریم، کلاس‌های کارخانه مدل، له کردن مهاجرت، دسته‌بندی شغل، محدود کردن نرخ بهبود یافته، اجزای Blade پویا، نمایش‌های صفحه‌بندی Tailwind، کمک‌های تست زمان و موارد دیگر را معرفی می‌کند. البته امروز شما امکان استفاده از لاراول نسخه 11 را دارید.


آشنایی با پکیج های ساخت فروشگاه اینترنتی در لاراول

پکیج های فروشگاهی برای لاراول وجود دارد که می توانند به راه اندازی سریع قابلیت های فروشگاهی در برنامه لاراول شما کمک کنند که در اینجا لیستی از محبوب ترین آنها آمده است:

  • Bagisto : بسته لاراول مبتنی بر کد و چند ویژگی برای فروشگاه اینترنتی
  • Aimeos : یک بسته فروشگاه ساز لاراول و راه حل فروشگاه آنلاین.
  • AvoRed : سبد خرید PHP ماژولار و قابل تنظیم.
  • Vanilo : یک چارچوب فروشگاه ساز لاراولی (مانند مجنتو یا پرستاشاپ)
  • GetCandy : یک API ایجاد سایت فروشگاهی با لاراول بدون هد که رایگان و اپن سورس است!

آشنایی با این پکیج ها به شما کمک می کند تصمیم درستی را در انتخاب صفر تا صد پروژه خود داشته باشید. بریم تا ادامه آموزش ساخت فروشگاه اینترنتی با لاراول را داشته باشیم. البته در تمام پروسه از سئو فروشگاه اینترنتی خود غافل نباشید!


اگر بخواید یک سایت فروشگاهی با لاراول بسازید این سه گزینه را خواهید داشت:

  1. یک CMS با لاراول انتخاب کنید و فروشگاه ساز سفارشی را به آن اضافه کنید.
  2. از پکیج های فروشگاه اینترنتی برای گسترش برنامه خود استفاده کنید.
  3. اپلیکیشن فروشگاه اینترنتی خود را از ابتدا بسازید.

ما در این مقاله روش سوم را در پیش گرفته ایم و به شما آموزش می دهیم که چگونه می توانید از ابتدا یک فروشگاه با لاراول بسازید و سپس Snipcart را اضافه کرده تا فروشگاه اینترنتی و سفارشی سازی سبد خرید را روی آن فعال کنید.

همه این گزینه های معرفی شده در این بخش از آموزش ساخت فروشگاه اینترنتی با لاراول دارای مزایای مشترکی همچون مقیاس پذیری بالا، سفارشی سازی آسان، عملکردهای فروشگاهی جدا و هستند. خوب بریم که شروع کنیم:


آموزش ساخت فروشگاه اینترنتی با لاراول

شروع آموزش ایجاد و ساخت فروشگاه اینترنتی با لاراول
شروع آموزش ایجاد و ساخت فروشگاه اینترنتی با لاراول

پیش نیازها
من فرض می‌کنم که شما قبلاً یک نصب PHP و Composer در حال اجرا دارید. اگر نه، می توانید آنها را اینجا و اینجا نصب کنید.
برای این آموزش ما از Sail استفاده می کنیم. این نرم افزار که با لاراول 8 معرفی شد، یک رابط خط فرمان سبک وزن برای تعامل با محیط توسعه پیش فرض داکر لاراول است که محیط توسعه و راه اندازی پایگاه داده ما را ساده می کند. Sail به ما این امکان را می دهد که به سرعت یک محیط توسعه و پایگاه داده را کاملاً جدا از محیط محلی خود راه اندازی کنیم.

از آنجایی که Sail با محیط Docker تعامل دارد، به این معنی است که شما به Docker Desktop (ابزاری عالی برای توسعه اپلیکیشن این روزها) نیاز خواهید داشت. البته اگر ترجیح شما این نباشد، می توانید یک پایگاه داده SQL محلی را به آن وصل کنید یا از Homestead از لاراول استفاده کنید. هوم استید یک Vagrant یکپارچه است که به شما امکان می دهد سریع کارتان را شروع کنید. بریم که ادامه آموزش ساخت فروشگاه اینترنتی با لاراول را داشته باشیم، امیدوارم خسته نشده باشید!


1. یک پروژه لاراول برای ساخت فروشگاه اینترنتی خود ایجاد کنید

لاراول یک دستور ساده برای راه اندازی یک پروژه ارائه می دهد.

  • ابتدا آن را با اجرا در دسترس قرار دهید: composer global require laravel/installer
  • سپس پروژه را ایجاد کنید: composer create-project laravel/laravel laravel-project
  • از طریق خط فرمان به محل پروژه وارد شوید : cd laravel-project
  • از این پس تمامی دستورات با artisan اجرا خواهند شد. Artisan یک رابط خط فرمان است که در لاراول گنجانده شده است و اجازه می دهد تا هر دستوری را با آن در پروژه لاراول انجام دهید.

2. محیط Sail را ایجاد کنید

Laravel Sail به همراه پروژه های Laravel 8 از قبل نصب شده است.با این حال، اگر می خواهید آن را روی یک پروژه موجود نصب کنید، دستورات زیر را اجرا کنید.

  • composer require laravel/sail –dev
  • php artisan sail:install

سپس ./vendor/bin/sail up را اجرا کنید تا محیط توسعه ما، از جمله پایگاه داده و سرور ایمیل، راه اندازی شود. (Snipcart ایمیل های مربوط به فروشگاه را برای شما مدیریت می کند)


3. ایجاد فهرست محصولات پایه

اکنون در ادامه آموزش ساخت فروشگاه اینترنتی با لاراول، بیایید محصولات خود را اضافه کنیم. برای این کار، ابتدا به مواد اولیه یعنی یک کنترلر و یک مدل داده در برنامه خود نیاز داریم که آنها را با دستور   php artisan make:model -a Ingredient ایجاد می کنیم.

با این کار چند فایل ایجاد می شود:

  • یک انتقال، در پایگاه داده/migrations/{date}_create_ingredients_table.php
  • یک کنترلر، در app/Http/Controllers/IngredientController.php
  • یک مدل، در app/Models/Ingredient.php
  • یک سید، در پایگاه داده/seeders/IngredientSeeder.php

در کنترلر، تمام متدها به جز index را حذف کنید. کنترلر از Eloquent ORM برای واکشی همه اجزای موجود در پایگاه داده استفاده می کند و آنها را به عنوان یک لیست JSON برمی گرداند. برای کسانی که نمی‌دانند: یک ORM مخفف نگاشت شی رابطه‌ای است و اساساً به ما امکان می‌دهد تا کوئری‌های پایگاه داده را به زبان کد مورد نظر خود بنویسیم (در مورد ما (PHP  لیست JSON ایجاد شده توسط کنترلری که از Eloquent ORM استفاده می کند به این صورت است:

<?php
namespace App\Http\Controllers;
  
/**
* Added by the make:model command
* This allows to query the DB for ingredients
*/
use App\Models\Ingredient;
use Illuminate\Http\Request;
/**
* We add this `use` to return our json resonse
*/
use Illuminate\Http\Response;
  
class IngredientController extends Controller
{
  public function index()
  {        
      /**
       * `Ingredient::all()` fetch all ingredients
       * `->jsonSerialize()` format them as a json list
       */
      return response()->json(Ingredient::all()->jsonSerialize());
  }
}

این روش همه اجزای مورد نیاز ما را از پایگاه داده گرفته و آنها را با فرمت JSON برمی گرداند.

تنها چیزی که برای فراخوانی متد ما از یک نقطه پایانی API وجود ندارد، پیوند دادن این روش کنترل‌کننده به یک مسیر است، یا اگر ترجیح می‌دهید، متد را با یک URL تطبیق دهید. در routes/api.php، خط زیر را اضافه کنید:

Route::get('/ingredients', [IngredientController::class,'index']);

این درخواست‌ GET در /api/ingredients را به روش فهرست ما در IngredientController نشان می‌دهد. داشتن یک API به ما امکان می دهد از خزنده JSON Snipcart برای تنظیم پویا قیمت استفاده کنیم. با این حال، اگر به API نیاز ندارید، می توانید از یک راه سنتی تر (MVC) استفاده کنید و به جای json، یک View را بازگردانید:

view('ingredients.list', ['ingredients' => Ingredient::all( )])

در ادامه آموزش ساخت فروشگاه اینترنتی با لاراول ، باید با استفاده از زبان قالب Blade در لاراول یک ویو برای آن ایجاد کنید.

اکنون که کنترلر ما آماده است، بیایید تعریف کنیم که چه چیزی در فایل Migration وجود دارد. من متد up را در روش خودم به این صورت تغییر دادم:

Schema::create('ingredients', function (Blueprint $table) {
    $table->bigIncrements('id');
    $table->string('name');
    $table->mediumText('description')->nullable();
    $table->string('category');
    $table->decimal('price_per_gram', 8, 3);
});

این مدل مشخص می‌کند که جدول اجزای پایگاه داده ما چگونه باید باشد. اما چگونه می توانیم آن دیتابیس را ایجاد کنیم؟ فقط باید این Migration را با sail artisan migrate فعال و اعمال کنیم. این دستور یک Migration را اعمال می کند، که اساساً به این معنی است که تغییرات مورد نیاز را در پایگاه داده ما (که در این مورد به معنای ایجاد جدول اجزای ما و اضافه کردن ستون ها و ردیف های مربوطه است) را اعمال می کند.

اکنون باید کنترلر ما کار کند و هنگام واکشی اطلاعات در {{YOUR_APP_PORT}}/api/ingredients، باید یک لیست خالی دریافت کنید.

من نمونه سید محصول نخستم را در یک Seeder در پایگاه داده/seeds/IngredientsTableSeeder.php (که با اجرای php artisan make:seeder IngredientsTableSeeder ایجاد شده است) اضافه کردم.

class IngredientsTableSeeder extends Seeder
{
 public function run()
 {
     DB::table('ingredients')->insert([
         [
             'name' => 'Quick Oats',
             'description' => '100% whole grain oats (quick cooking)',
             'category' => 'oats',
             'price_per_gram' => 0.007,
         ],
/* ... many more! ... */
    ]);
 }
}

از Seders می توان در توسعه برای ساخت داده های اولیه در DB استفاده کرد. حالا برای قرار دادن آن داده ها در پایگاه داده، sail artisan db:seed –class=IngredientSeeder را اجرا کنید. اگر دستور بالا را اجرا کنید هنگام فراخوانی /api/ingredients همه داده های اولیه را به صورت JSON دریافت خواهید کرد.


4. استفاده از مدل های پیشرفته برای دستور العمل های سفارشی

شما می توانید در آنجا توقف کرده، و پایه و اساس یک API محصول بدون سر و کار برای فروش مواد اولیه را داشته باشید. اما از آنجایی که ما می خواهیم دستور العمل های پر کاربرد بسازیم، باید راهی برای ترکیب مواد در یک دستور غذای سفارشی داشته باشیم که از طریق مدل های پیشرفته لاراول به ما این امکان داده می شود.

ما یک کنترلر “Recipe” را با مدل آن اضافه می کنیم. مدل دستور پخت ما از مواد زیادی با مقادیر متفاوت تشکیل شده است که می‌توانیم این را با طرح زیر نشان دهیم (قول می‌دهم، این تنها باری است که از UML استفاده می‌کنیم):

Class Diagram of Ingredients and Recipes
Class Diagram of Ingredients and Recipes

IngredientRecipe یک جدول ارتباطی است. در یک رابطه چند به چند، به این معنی که بسیاری از Ingredient ها را می توان به بسیاری از دستور العمل ها و بسیاری از دستور العمل ها را می توان به بسیاری از مواد مرتبط کرد، یک جدول ویژه برای نشان دادن هر پیوند بین دو جدول وجود دارد.

در این مورد، من همچنین مقداری اضافه کرده‌ام که نشان می‌دهد «چه مقدار» از هر ماده در یک دستور غذا وجود دارد.

بیایید جداول جدید را با دستور ترمینال php artisan make:migration create_recipes_and_relation ایجاد کرده و {date}_create_recipes_and_relation.php را طوری ویرایش کنیم که حاوی موارد زیر باشد:

<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
class CreateRecipesAndRelation extends Migration
{
  public function up()
  {
      /**
       * This is the main table for a recipe
       * created dynamically by a customer on the site
       */
      Schema::create('recipes', function (Blueprint $table) {
          $table->uuid('id')->primary();
          $table->string('name');
          $table->string('size');
          $table->timestamps();
      });
          
      /**
       * This is the "relation" table which serve to link
       * a recipe to a list of ingredients.
       * That one essentialy have reference
       * to the other tables' ids.
       * But also the quantity of each ingredients
       */
      Schema::create('ingredient_recipe', function (Blueprint $table) {
          $table->bigIncrements('id');
          $table->timestamps();
          $table->uuid('recipe_id')->index();
          $table->bigInteger('ingredient_id')->unsigned()->index();
          $table->foreign('recipe_id')->references('id')->on('recipes');
          $table->foreign('ingredient_id')->references('id')->on('ingredients');
          $table->decimal('quantity', 2, 3);
      });
  }
  public function down()
  {
      Schema::dropIfExists('ingredient_recipe');
      Schema::dropIfExists('recipes');
  }
}

حالا بیایید با چند روش یک RecipeController ایجاد کنیم.

در ابتدا یک روش ذخیره برای ذخیره سازی دستور العمل های سفارشی در پایگاه داده انجام داده و در RecipeController.php کد زیر را اضافه کنید:

public function save(Request $request)
    {
        $recipe = new Recipe;
        $recipe->name = $request->input('name');
        $recipe->size = $request->input('size');
        $recipe->save();

        $items = array_map(function ($item) use ($recipe) {
            return [
                'recipe_id' => $recipe->id,
                'ingredient_id' => $item['id'],
                'quantity' => $item['quantity'],
            ];
        }, $request->input('items'));

        IngredientRecipe::insert($items);

        $ingredients = Recipe::find($recipe->id)
            ->ingredients->map(function ($ingredient) {
                $ingredient->quantity = $ingredient->pivot->quantity;
                return $ingredient;
            });

        $price = $this->calculatePrice($ingredients, $recipe->size);

        return response()
            ->json([
                'id' => $recipe->id,
                'name' => 'Recipe ' . $recipe->name . ' (' . $recipe->size . ')',
                'url' => '/api/recipe/' . $recipe->id,
                'price' => $price,
            ]);
    }

سپس، با افزودن کد زیر به routes/api.php، آن مسیر را ثبت می کنیم: Route::post(‘/recipes’, ‘RecipeController@save’);.

این روش دستور غذا را ذخیره می کند. فقط در این صورت ورودی‌های جدول رابطه درج می‌شوند، زیرا هم به «دستور غذا» و هم به هر «مواد تشکیل دهنده» بستگی دارند. متد save با بازگرداندن یک JSON از یک تعریف محصول (حداقل: شناسه، نام، URL، قیمت) تکمیل می‌شود که می‌تواند مستقیماً به سبد خرید در قسمت جلویی ارسال شود.

حالا بیایید یک متد fetch با کد زیر در RecipeController.php اضافه کنیم:

public function fetch($id) {
   $recipe = Recipe::find($id);
   $ingredients = $recipe->ingredients
       ->map(function($ingredient) {
           $ingredient->quantity = $ingredient->pivot->quantity;
           return $ingredient;
       });
       
   $price = $this->calculatePrice($ingredients, $recipe->size);
   
   return response()
       ->json([
           'id' => $recipe->id,
           'name' => 'Recipe '.$recipe->name.' ('.$recipe->size.')',
           'url' => '/api/recipe/'.$recipe->id,
           'price' => $price,
       ]);
}

در واقع می توانید با فراخوانی fetch به انتهای متد save برگردید تا کد را کاهش دهید.

در اینجا دوباره، اجازه دهید آن مسیر را با افزودن کد زیر به routes/api.php ثبت کنیم: Route::get(‘/recipe/{id}’, ‘RecipeController@fetch’); .

و در نهایت، بیایید یک متد پریویو به کنترلر را در ادامه آموزش ساخت فروشگاه اینترنتی با لاراول به کدهای خود اضافه کنیم:

public function preview(Request $request)
    {
        $items = $request->input('items');
        $ingredientIds = array_map(function ($item) {
            return $item['id'];
        }, $items);

        $quantityForId = function($id) use($items) {
            for($i = 0; $i < count($items); $i++) {
                if($items[$i]['id'] == $id) {
                    return $items[$i]['quantity'];
                }
            }
        };

        $ingredients = Ingredient::whereIn('id', $ingredientIds)
            ->get()
            ->map(function($ingredient) use($quantityForId) {
                $ingredient->quantity = $quantityForId($ingredient->id);
                return $ingredient;
            });

        $size = $request->input('size');

        return response()
            ->json([
                'price' => $this->calculatePrice($ingredients, $size),
            ]);
    }

حالا اگر اصل مطلب را دریافت کرده باشید، می دانید که باید Route::post(‘/recipes/preview’, [RecipeController::class, ‘preview’]); به routes/api.php. اضافه کنید.

متوجه خواهید شد که مسیر URL محصولی است که از نقطه پایانی قبلی برگردانده شده است. این به خزنده Snipcart اجازه می دهد تا قیمت مخلوط بلغور جو دوسر خریداری شده (دستور العمل ذخیره شده) را تأیید کند.

آن یکی تقریباً شبیه به پایان متد save است. آوردن هر یک از مواد تشکیل دهنده یک دستور غذا و مقدار آن.

این روش‌های کنترل‌کننده حاوی چند کاربرد جالب از Eloquent هستند. به عنوان مثال، متد map به شما امکان می دهد داده های درخواست شده را به طور تمیز و کاربردی تغییر داده و سپس به مواد تشکیل دهنده دسترسی پیدا کرده تا مواد مرتبط با دستور غذا را دریافت کنید.

تنها چیزی که برای درک ORM از رابطه موجود در طرحواره‌های ما لازم است، اضافه کردن یک مدل برای جدول اتصال IngredientRecipe با دستور زیر است: php artisan make:model IngredientRecipe. در app/IngredientRecipe.php، اجازه دهید آن را به جای Model، Pivot را گسترش دهیم:

<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Relations\Pivot;
class IngredientRecipe extends Pivot
{
}

حالا بیایید با دستور زیر یک مدل دستور غذا بسازیم: php artisan make:model Recipe:

<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Recipe extends Model
{
    public function ingredients()
    {
        return $this->belongsToMany('App\Models\Ingredient')
            ->using('App\Models\IngredientRecipe')
            ->withPivot(['quantity']);
    }
}

ردیفه ! و حالا یک API JSON داریم که ارائه می دهد:

  • نقطه پایانی برای فهرست کردن مواد موجود
  • نقطه پایانی برای ذخیره یک دستور غذا با تمام مقدار مواد تشکیل دهنده آن
  • نقطه پایانی برای بازیابی قیمت دستور غذای ذخیره شده (همانطور که توسط خزنده Snipcart انتظار می رود)

بنابراین ما داده ها و منطق خود را داریم، اما یک فروشگاه جو دوسر ممتاز بدون کمی ذوق بصری چیست؟

بیایید با نگاه کردن به نحوه پیوند دادن این نقاط پایانی API به یک صفحه اصلی فروشگاه اینترنتی، این مشکل را حل کنیم.


5. اتصال همه اینها به فرانتند

من از Vue.js برای قسمت ظاهری استفاده کردم، که ما در Snipcart از طرفداران پر و پا قرص آن به حساب می آییم. با دستورات زیر می توانید یک پروژه barebone Vue اضافه کنید:

  • composer require laravel/ui --dev
  • php artisan ui vue
  • npm install

این فایل‌های اساسی Vue.js را در پوشه Resources تولید می‌کند که می‌توانند در حالت «watch» با sail npm run watch کامپایل شوند و به نقطه پایانی ریشه ما ارائه شوند.

برای جستجوی API ما، از کتابخانه Axios استفاده کرده‌ایم.

فرانت اند ابتدا لیست مواد تشکیل دهنده ما را از /api/ingredients بارگیری می کند. سپس مشتری می تواند برخی از آنها را برای دستور غذا انتخاب کرده، نامی به دستور غذا بدهد، با استفاده از روش پیش نمایشی که قبلا ایجاد کردیم، پیش نمایش قیمت داشته باشد و اگر می خواهد از این روش استفاده کند، آن را ذخیره کند.

async created() {
    const response = await axios.get("/api/ingredients");
    this.allIngredients = response.data;
  }

هنگامی که این کار انجام شد، مشتریان می‌توانند روی دکمه خرید که این کد را اجرا می‌کند، کلیک کنند.

async buy() {
  const payload = {
      name: this.name,
      size: this.size,
      items: this.ingredients.map(x => ({
          id: x.id,
          quantity: x.quantity,
      })),
  };
  const response = await axios.post('/api/recipes', payload);
  const host = window.location.protocol+'//'+window.location.host;
  Snipcart.api.cart.items.add({
      ...response.data,
      url: host+response.data.url,
  });

بدنه درخواست مورد انتظار POST /api/recipes را ایجاد می کند و تعریف محصولی را که برای ادغام سبد خرید خود از آن استفاده می کنیم، برمی گرداند.


6. یکپارچه سازی Snipcart

در ادامه آموزش طراحی فروشگاه اینترنتی با لاراول ، می‌توانیم دستور تهیه بلغور جو دوسر را در وب‌سایت خود ایجاد کنیم. بیایید یک سبد خرید را با Snipcart ادغام کرده تا مشتریان شما بتوانند آنها را خریداری کنند.

در resources/views/welcome.blade.php، نکات پیش اتصال Snipcart و شیوه نامه پیش فرض را در بین گره های <head> Html اضافه کنید.

<link rel="preconnect" href="https://app.snipcart.com">
<link rel="preconnect" href="https://cdn.snipcart.com">

<link rel="stylesheet" href="https://cdn.snipcart.com/themes/SNIPCART_MOST_RECENT_VERSION/default/snipcart.css" />

در گره‌های <body> Html، اسکریپت Snipcart را به همراه ویژگی شناسه “snipcart” و کلید API عمومی خود اضافه کنید، که به صورت زیر است:

<div hidden id="snipcart" data-api-key="YOUR_PUBLIC_API_KEY"></div>
        <script async src="https://cdn.snipcart.com/themes/MOST_RECENT_SNIPCART_VERSION/default/snipcart.js"></script>

اکنون می‌توانیم با اضافه کردن کلاس snipcart-checkout به هر دکمه‌ای در موضوع خود، خلاصه‌ای از سبد خرید را ادغام کنیم.

<button class="snipcart-customer-signin"
        >خرید</button
      >

اگر به مخزن نگاه کنید، خواهید دید که کد کمی متفاوت است، زیرا من از Vuetify برای استایل پروژه استفاده کردم.

اگر اطلاعات بیشتری در مورد موارد فوق می‌خواهید، مستندات به جزئیات کامل در مورد نصب می‌پردازند.

مرحله نهایی در یکپارچه سازی ما اضافه کردن محصولات با استفاده از Javascript API Snipcart است.

بیایید این کار را با افزودن کد زیر انجام دهیم تا روش خرید خود را با استفاده از تعریف محصول برگشتی POST /api/recipes تکمیل کنیم:

async buy() {    
    // rest of the method we made earlier in this tutorial
    Snipcart.api.cart.items.add({
        ...response.data,
        url: host+response.data.url,
        });}

سبد خرید ما اکنون فعال است، به این معنی که کاربران ما اکنون می توانند دستور العمل های سفارشی خود را ایجاد و خریداری کنند! دمو لایو ساخته شده در این آموزش ساخت فروشگاه اینترنتی با لاراول را اینجا ببینید و Github repo را در اینجا می توانید داشته باشید.


ختم کلام

از آنجایی که روزی هیچ تجربه ای در PHP نداشتم، وقتی تیم از من خواست که لاراول را بررسی کنم، کمی در مورد رام کردن elePHPant مضطرب بودم. باید بگویم که از اکوسیستم لاراول و همه چیزهایی که در اختیارم قرار می دهد شگفت زده شدم. من ساختار فایل لاراول را کاملاً بصری یافتم.

علاوه بر این، ORM Eloquent قادر است schema های کاملاً پیچیده را مدل سازی کند! آخرین اما نه کم اهمیت، خط فرمان artisan واقعا توسعه را ساده می کند، در حالی که خط فرمان sail و built-in docker نیز همین کار را برای محیط توسعه شما انجام می دهند. این ها همگی روند توسعه را به همان اندازه یکپارچه می کنند!

این آموزش ساخت فروشگاه اینترنتی با لاراول به ما این امکان را می دهد که کنترل کاملی بر نحوه مدیریت داده ها در فروشگاهمان داشته باشیم. به عنوان یک چارچوب MVC با ویژگی های کامل با پشتیبانی درجه یک از JSON، افزودن ادغام های دیگر مانند webhook ها بسیار راحت خواهد بود. برای تیم دیجیتال مارکتینگ آوادیس این افتخاری بود که بتواند این آموزش را خدمت همراهان و همکاران آینده خود ارائه دهد.

میانگین امتیاز : 0 / 5. تعدا آرا : 0

ثبت امتیاز شما به این مطلب

photo 2023 09 11 00 00 54
نویسنده
امیرحسین ستاری
حدود 15 سال هست که با علاقه به فرانت و CSS HTML Java Script شروع کردم و بعد از آن در زمینه برنامه نویسی PHP و لاراول مشغول فعالیت هستم. در زمینه استارتاپ، سئو و راهکارهای دیجیتال مارکتینگ فعالیت دارم و بصورت روزانه مطالعه می‌کنم.

شما نظری در این مورد ندارید؟