Rumah >rangka kerja php >ThinkPHP >Cara menggunakan ThinkPHP6 untuk melaksanakan sistem pengurusan pesanan

Cara menggunakan ThinkPHP6 untuk melaksanakan sistem pengurusan pesanan

PHPz
PHPzasal
2023-06-20 08:42:461902semak imbas

Dengan perkembangan Internet dan peningkatan e-dagang, semakin banyak syarikat mula menggunakan sistem pengurusan pesanan dalam talian untuk mengurus pesanan dengan lebih baik, meningkatkan kecekapan kerja dan menyediakan perkhidmatan pelanggan yang lebih baik. Artikel ini akan memperkenalkan cara menggunakan rangka kerja ThinkPHP6 untuk membangunkan sistem pengurusan pesanan ringkas, meliputi senarai pesanan, butiran pesanan, carian, pengisihan, halaman dan fungsi lain.

  1. Persediaan

Pertama, anda perlu memasang PHP, MySQL dan Komposer. Selepas memasang komponen yang diperlukan ini, anda boleh memasang ThinkPHP6. Jika anda tidak biasa dengan ThinkPHP6, anda boleh membaca dokumentasi rasmi atau merujuk kepada beberapa tutorial yang berkaitan.

  1. Buat pangkalan data dan jadual data

Sebelum anda mula membangunkan sistem pengurusan pesanan, anda perlu mencipta pangkalan data. Buat pangkalan data bernama "order_system" dalam MySQL, dan kemudian buat jadual data bernama "orders".

Jadual data mengandungi medan berikut:

id - ID pesanan

nama_pelanggan - nama pelanggan

e-mel_pelanggan - e-mel pelanggan

nama_produk - nama produk

harga_produk - harga produk

kuantiti_produk - kuantiti produk

dicipta_pada - masa membuat pesanan

dikemas kini - masa kemas kini pesanan

  1. Buat model dan pengawal

Dalam ThinkPHP6, model sepadan dengan jadual data dan pengawal sepadan dengan laluan.

Pertama, buat model bernama "Pesanan", yang akan sepadan dengan jadual data "pesanan".

php artisan make:model Order -m

Tambahkan pada kod yang dicurahkan

namespace appmodel;

use thinkModel;

class Order extends Model
{

}

Kemudian, cipta pengawal yang dipanggil "Pesanan" dan kaedah "indeks" yang akan memaparkan paparan senarai pesanan.

php artisan make:controller Order --resource

Tambah pada Tindakan, kod

public function index()
{
    $orders = Order::paginate(10);
    return view('order/index', ['orders' => $orders]);
}
  1. Buat paparan

Seterusnya, buat paparan bernama "index.blade.php" , digunakan untuk memaparkan senarai pesanan, yang merangkumi fungsi carian, pengisihan dan halaman.

Mula-mula, buat fail paparan bernama "index.blade.php" dalam direktori "order", dan kemudian tambah kod berikut:

@extends('layout')

@section('content')
    <h2>订单列表</h2>

    <form action="{{route('orders.index')}}" method="get">
        <div class="form-group">
            <input type="text" name="q" value="{{$q}}" class="form-control" placeholder="搜索">
        </div>

        <button type="submit" class="btn btn-primary">搜索</button>
    </form>

    <table class="table">
        <thead>
        <tr>
            <th>ID</th>
            <th>客户姓名</th>
            <th>客户电子邮件</th>
            <th>产品名称</th>
            <th>产品价格</th>
            <th>产品数量</th>
            <th>订单创建时间</th>
            <th></th>
        </tr>
        </thead>
        <tbody>
        @foreach ($orders as $order)
            <tr>
                <td>{{$order->id}}</td>
                <td>{{$order->customer_name}}</td>
                <td>{{$order->customer_email}}</td>
                <td>{{$order->product_name}}</td>
                <td>{{$order->product_price}}</td>
                <td>{{$order->product_quantity}}</td>
                <td>{{$order->created_at}}</td>
                <td><a href="{{route('orders.show', $order->id)}}" class="btn btn-primary">详情</a></td>
            </tr>
        @endforeach
        </tbody>
    </table>

    {{$orders->links()}}
@endsection

Dalam paparan ini, gaya Bootstrap digunakan , juga menambah kotak carian dan kawalan halaman.

  1. Buat kaedah butiran pesanan dan lihat

Kemudian, buat kaedah bernama "show" dan paparan bernama "show.blade.php" untuk butiran pesanan Paparan.

Tambah kod berikut dalam pengawal "Pesanan":

public function show($id)
{
    $order = Order::findOrFail($id);
    return view('order/show', ['order' => $order]);
}

Buat fail paparan bernama "show.blade.php" dalam direktori "pesanan" dan tambah kod berikut:

@extends('layout')

@section('content')
    <h2>订单详情</h2>

    <table class="table">
        <tbody>
        <tr>
            <th>ID</th>
            <td>{{$order->id}}</td>
        </tr>
        <tr>
            <th>客户姓名</th>
            <td>{{$order->customer_name}}</td>
        </tr>
        <tr>
            <th>客户电子邮件</th>
            <td>{{$order->customer_email}}</td>
        </tr>
        <tr>
            <th>产品名称</th>
            <td>{{$order->product_name}}</td>
        </tr>
        <tr>
            <th>产品价格</th>
            <td>{{$order->product_price}}</td>
        </tr>
        <tr>
            <th>产品数量</th>
            <td>{{$order->product_quantity}}</td>
        </tr>
        <tr>
            <th>订单创建时间</th>
            <td>{{$order->created_at}}</td>
        </tr>
        <tr>
            <th>订单更新时间</th>
            <td>{{$order->updated_at}}</td>
        </tr>
        </tbody>
    </table>

    <a href="{{route('orders.index')}}" class="btn btn-primary">返回</a>
@endsection
  1. Tambah fungsi carian, isihan dan halaman

Untuk melaksanakan fungsi carian, isihan dan halaman, kaedah "indeks" perlu diubah suai.

Tambahkan kod berikut dalam kaedah "indeks" pengawal "Pesanan":

public function index(Request $request)
{
    $q = $request->input('q');

    $orders = Order::when($q, function ($query) use ($q) {
            $query->where('customer_name', 'like', "%$q%")
                ->orWhere('customer_email', 'like', "%$q%")
                ->orWhere('product_name', 'like', "%$q%");
        })
        ->orderBy('created_at', 'desc')
        ->paginate(10)
        ->appends(['q' => $q]);

    return view('order/index', ['orders' => $orders, 'q' => $q]);
}

Dalam kod ini, kelas IlluminateSupportFacadesRequest digunakan untuk mendapatkan parameter carian "q", dan " kaedah orderBy" untuk mengisih mengikut urutan terbalik masa penciptaan. Kemudian, gunakan kaedah "penomboran" untuk menomborkan muka surat, dan kaedah "menambahkan" untuk menambah parameter carian pada pautan yang dinomborkan.

  1. Ujian

Anda kini boleh menguji sistem pengurusan pesanan yang telah anda buat. Masukkan http://localhost/orders dalam pelayar anda untuk melihat senarai pesanan. Selepas memasukkan kata kunci dan mengklik butang carian, anda boleh melihat hasil carian selepas mengklik butang butiran, anda boleh melihat butiran pesanan. Di bawah pautan penomboran, anda boleh melihat kawalan halaman.

Ringkasan

Pada ketika ini, kami telah menyelesaikan semua langkah untuk mencipta sistem pengurusan pesanan ringkas menggunakan rangka kerja ThinkPHP6. Artikel ini menerangkan cara membuat jadual, model dan pengawal data serta menunjukkan cara menggunakan fail paparan untuk membuat data pesanan, mencari, mengisih dan menomborkan. Dengan mempelajari tutorial ini, anda boleh mempunyai pemahaman yang lebih mendalam tentang rangka kerja ThinkPHP6 dan boleh menggunakan rangka kerja ThinkPHP6 untuk membangunkan sistem perniagaan anda sendiri.

Atas ialah kandungan terperinci Cara menggunakan ThinkPHP6 untuk melaksanakan sistem pengurusan pesanan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn