ホームページ > バックエンド開発 > PHPチュートリアル > Laravel 5.6 の CURD 操作 (詳細なコード例)

Laravel 5.6 の CURD 操作 (詳細なコード例)

藏色散人
リリース: 2023-04-05 12:50:01
オリジナル
3869 人が閲覧しました






##この記事では、laravel 5.6バージョンの基本的なクラッド(作成、読み取り、更新、削除)アプリケーションモジュールを共有します。以下の手順に従って、laravel 5.6 で CRUD アプリケーションを作成できます。

Laravel 5.6 の CURD 操作 (詳細なコード例)

Laravel は、多くの高度な開発機能を備えた人気のオープンソース PHP MVC フレームワークです。あなたがlaravel 5.6アプリケーションの学習者または初心者である場合、crudアプリケーションについて知り、さらに学ぶことは常に非常に役立ちます。 (関連したlaravelビデオチュートリアル: 「

最新Laravel Mall実践ビデオチュートリアル」)

以下では、挿入、更新、削除、表示と商品ページネーションのサンプルを作成します。新しい製品の作成、製品の表示、製品の編集、リストからの製品の削除を行うだけです。

ステップ 1: Laravel 5.6 をインストールする

ターミナルで create-project コマンドを実行して、Laravel をインストールできます:

composer create-project --prefer-dist laravel/laravel blog
ログイン後にコピー

(関連する推奨事項: "

コンポーザーを介して Laravel フレームワークをインストールする方法は?>>)

ステップ 2: データベース構成

インストールが完了したら、crud を提供しますfor laravel 5.6 アプリケーションは、データベース名、ユーザー名、パスワードなどのデータベース構成を実行します。したがって、.env ファイルを開いて次のように関連情報を入力しましょう:

.env

DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=here your database name(blog)
DB_USERNAME=here database username(root)
DB_PASSWORD=here database password(root)
ログイン後にコピー

ステップ 3: 製品テーブルとモデルを作成します

製品用の粗末なアプリケーションを作成します。したがって、Laravel 5.6 の PHP 職人コマンドを使用して製品テーブルの移行を作成する必要があります。最初に次のコマンドを使用します:

php artisan make:migration create_products_table --create=products
ログイン後にコピー

このコマンドを実行した後、パス

database/migrations に移行を作成できます。 ファイルが見つかりました。products テーブルを作成するには、次のコードを移行ファイルに配置する必要があります。

<?php

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;


class CreateProductsTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create(&#39;products&#39;, function (Blueprint $table) {
            $table->increments(&#39;id&#39;);
            $table->string(&#39;name&#39;);
            $table->text(&#39;detail&#39;);
            $table->timestamps();
        });
    }


    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists(&#39;products&#39;);
    }
}
ログイン後にコピー

ステップ 4: リソース ルーティングの追加

このステップでは、製品クラッド アプリケーションのリソース ルーティングを追加する必要があります。したがって、routes/web.php ファイルを開き、次のルートを追加します。

routes/web.php

Route::resource(&#39;products&#39;,&#39;ProductController&#39;);
ログイン後にコピー

ステップ 5: ProductController の作成

次に、新しいコントローラー ProductController を作成する必要があります。そこで、次のコマンドを実行して新しいコントローラーを作成します。リソース コントローラーの作成には次のコントローラーが使用されます。

Create ProductController

php artisan make:controller ProductController --resource --model=Product
ログイン後にコピー

次のコマンドを実行すると、パス app/Http/Controllers/ProductController.php に新しいファイルが見つかります。

このコントローラーでは、デフォルトで次の 7 つのメソッドが作成されます:

1)index()

2)create()

3)保存()

4)表示()

5)編集()

6)更新()

7)破壊( )

それでは、以下のコードをコピーして、ProductController.php ファイルに入れてみましょう。

app/Http/Controllers/ProductController.php

<?php

namespace App\Http\Controllers;

use App\Product;
use Illuminate\Http\Request;

class ProductController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        $products = Product::latest()->paginate(5);

        return view(&#39;products.index&#39;,compact(&#39;products&#39;))
            ->with(&#39;i&#39;, (request()->input(&#39;page&#39;, 1) - 1) * 5);
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        return view(&#39;products.create&#39;);
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store(Request $request)
    {
        request()->validate([
            &#39;name&#39; => &#39;required&#39;,
            &#39;detail&#39; => &#39;required&#39;,
        ]);

        Product::create($request->all());

        return redirect()->route(&#39;products.index&#39;)
                        ->with(&#39;success&#39;,&#39;Product created successfully.&#39;);
    }

    /**
     * Display the specified resource.
     *
     * @param  \App\Product  $product
     * @return \Illuminate\Http\Response
     */
    public function show(Product $product)
    {
        return view(&#39;products.show&#39;,compact(&#39;product&#39;));
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  \App\Product  $product
     * @return \Illuminate\Http\Response
     */
    public function edit(Product $product)
    {
        return view(&#39;products.edit&#39;,compact(&#39;product&#39;));
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \App\Product  $product
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, Product $product)
    {
         request()->validate([
            &#39;name&#39; => &#39;required&#39;,
            &#39;detail&#39; => &#39;required&#39;,
        ]);

        $product->update($request->all());

        return redirect()->route(&#39;products.index&#39;)
                        ->with(&#39;success&#39;,&#39;Product updated successfully&#39;);
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  \App\Product  $product
     * @return \Illuminate\Http\Response
     */
    public function destroy(Product $product)
    {
        $product->delete();

        return redirect()->route(&#39;products.index&#39;)
                        ->with(&#39;success&#39;,&#39;Product deleted successfully&#39;);
    }
}
ログイン後にコピー

OK、次のコマンドを実行すると、app/Product.php が見つかり、次の内容を Product.php ファイルに追加します。

app/Product.php

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Product extends Model
{
    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        &#39;name&#39;, &#39;detail&#39;
    ];
}
ログイン後にコピー

ステップ 6: Blade ファイルの作成

ここで、最後のステップに入ります。このステップでは、ブレード ファイルを作成するだけです。したがって、主にレイアウト ファイルを作成し、次に新しいフォルダー「products」を作成し、次に crud アプリのブレード ファイルを作成する必要があります。最後に、次のブレード ファイルを作成する必要があります:

1)layout.blade.php

2)index.blade.php

3)show.blade.php

4) form.blade.php

5) create.blade.php

6) edit.blade.php

以下を作成しましょうファイルを配置し、以下のコードを入力します。

resources/views/products/layout.blade.php

<!DOCTYPE html>
<html>
<head>
	<title>Laravel 5.6 CRUD Application</title>
	<link href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.0.0-alpha/css/bootstrap.css" rel="stylesheet">
</head>
<body>

<div class="container">
    @yield(&#39;content&#39;)
</div>

</body>
</html>
ログイン後にコピー

resources/views/products/index.blade.php

@extends(&#39;products.layout&#39;)

@section(&#39;content&#39;)
    <div class="row">
        <div class="col-lg-12 margin-tb">
            <div class="pull-left">
                <h2>Laravel 5.6 CRUD Example from scratch</h2>
            </div>
            <div class="pull-right">
                <a class="btn btn-success" href="{{ route(&#39;products.create&#39;) }}"> Create New Product</a>
            </div>
        </div>
    </div>

    @if ($message = Session::get(&#39;success&#39;))
        <div class="alert alert-success">
            <p>{{ $message }}</p>
        </div>
    @endif

    <table class="table table-bordered">
        <tr>
            <th>No</th>
            <th>Name</th>
            <th>Details</th>
            <th width="280px">Action</th>
        </tr>
        @foreach ($products as $product)
        <tr>
            <td>{{ ++$i }}</td>
            <td>{{ $product->name }}</td>
            <td>{{ $product->detail }}</td>
            <td>
                <form action="{{ route(&#39;products.destroy&#39;,$product->id) }}" method="POST">

                    <a class="btn btn-info" href="{{ route(&#39;products.show&#39;,$product->id) }}">Show</a>
                    <a class="btn btn-primary" href="{{ route(&#39;products.edit&#39;,$product->id) }}">Edit</a>

                    @csrf
                    @method(&#39;DELETE&#39;)

   
                    <button type="submit" class="btn btn-danger">Delete</button>
                </form>
            </td>
        </tr>
        @endforeach
    </table>

    {!! $products->links() !!}

@endsection
ログイン後にコピー

resources/views/products/show。 Blade.php

@extends(&#39;products.layout&#39;)

@section(&#39;content&#39;)
    <div class="row">
        <div class="col-lg-12 margin-tb">
            <div class="pull-left">
                <h2> Show Product</h2>
            </div>
            <div class="pull-right">
                <a class="btn btn-primary" href="{{ route(&#39;products.index&#39;) }}"> Back</a>
            </div>
        </div>
    </div>

    <div class="row">
        <div class="col-xs-12 col-sm-12 col-md-12">
            <div class="form-group">
                <strong>Name:</strong>
                {{ $product->name }}
            </div>
        </div>
        <div class="col-xs-12 col-sm-12 col-md-12">
            <div class="form-group">
                <strong>Details:</strong>
                {{ $product->detail }}
            </div>
        </div>
    </div>
@endsection
ログイン後にコピー

resources/views/products/create.blade.php

@extends(&#39;products.layout&#39;)

@section(&#39;content&#39;)
    <div class="row">
        <div class="col-lg-12 margin-tb">
            <div class="pull-left">
                <h2>Add New Product</h2>
            </div>
            <div class="pull-right">
                <a class="btn btn-primary" href="{{ route(&#39;products.index&#39;) }}"> Back</a>
            </div>
        </div>
    </div>

    @if ($errors->any())
        <div class="alert alert-danger">
            <strong>Whoops!</strong> There were some problems with your input.<br><br>
            <ul>
                @foreach ($errors->all() as $error)
                    <li>{{ $error }}</li>
                @endforeach
            </ul>
        </div>
    @endif

    <form action="{{ route(&#39;products.store&#39;) }}" method="POST">
        @csrf

         <div class="row">
            <div class="col-xs-12 col-sm-12 col-md-12">
                <div class="form-group">
                    <strong>Name:</strong>
                    <input type="text" name="name" class="form-control" placeholder="Name">
                </div>
            </div>
            <div class="col-xs-12 col-sm-12 col-md-12">
                <div class="form-group">
                    <strong>Detail:</strong>
                    <textarea class="form-control" style="height:150px" name="detail" placeholder="Detail"></textarea>
                </div>
            </div>
            <div class="col-xs-12 col-sm-12 col-md-12 text-center">
                    <button type="submit" class="btn btn-primary">Submit</button>
            </div>
        </div>

    </form>

@endsection
ログイン後にコピー

resources/views/products/edit.blade.php

@extends(&#39;products.layout&#39;)

@section(&#39;content&#39;)
    <div class="row">
        <div class="col-lg-12 margin-tb">
            <div class="pull-left">
                <h2>Edit Product</h2>
            </div>
            <div class="pull-right">
                <a class="btn btn-primary" href="{{ route(&#39;products.index&#39;) }}"> Back</a>
            </div>
        </div>
    </div>

    @if ($errors->any())
        <div class="alert alert-danger">
            <strong>Whoops!</strong> There were some problems with your input.<br><br>
            <ul>
                @foreach ($errors->all() as $error)
                    <li>{{ $error }}</li>
                @endforeach
            </ul>
        </div>
    @endif

    <form action="{{ route(&#39;products.update&#39;,$product->id) }}" method="POST">
        @csrf
        @method(&#39;PUT&#39;)

         <div class="row">
            <div class="col-xs-12 col-sm-12 col-md-12">
                <div class="form-group">
                    <strong>Name:</strong>
                    <input type="text" name="name" value="{{ $product->name }}" class="form-control" placeholder="Name">
                </div>
            </div>
            <div class="col-xs-12 col-sm-12 col-md-12">
                <div class="form-group">
                    <strong>Detail:</strong>
                    <textarea class="form-control" style="height:150px" name="detail" placeholder="Detail">{{ $product->detail }}</textarea>
                </div>
            </div>
            <div class="col-xs-12 col-sm-12 col-md-12 text-center">
              <button type="submit" class="btn btn-primary">Submit</button>
            </div>
        </div>

    </form>

@endsection
ログイン後にコピー

これで、準備ができています 粗末なアプリケーションの例を実行します。次のコマンドを実行してすぐに実行します。

php artisan serve
ログイン後にコピー

最後に、ブラウザで次の URL を開いてテストを表示できます。

http://localhost:8000/products
ログイン後にコピー

この記事は、 Laravel 5.6 の CURD 操作、つまり作成、読み取り、更新、削除の操作が、困っている友人の役に立てば幸いです。






#

以上がLaravel 5.6 の CURD 操作 (詳細なコード例)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート