PHP コーディング実践: 商品のマルチスペック SKU 機能を実装する方法
EC サイトにおけるマルチスペック SKU (Stock Keeping Unit) 機能の製品は非常に一般的なニーズです。複数仕様の SKU により、サイズ、色、容量などの商品のさまざまな属性を簡単に管理し、さまざまな属性の組み合わせに応じた在庫管理と価格計算を実装できます。この記事では、PHP を使用して製品のマルチ仕様 SKU 機能を実装する方法と、関連するコード例を紹介します。
1. データベースの設計
まず、製品の複数の仕様情報を格納するデータベース テーブルを設計する必要があります。以下は、簡単なデータベース テーブルの設計例です:
CREATE TABLE `products` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) NOT NULL, `price` decimal(10,2) NOT NULL, PRIMARY KEY (`id`) ); CREATE TABLE `product_variants` ( `id` int(11) NOT NULL AUTO_INCREMENT, `product_id` int(11) NOT NULL, `attribute_1` varchar(255) NOT NULL, `attribute_2` varchar(255) NOT NULL, `attribute_3` varchar(255) NOT NULL, `sku` varchar(255) NOT NULL, `stock` int(11) NOT NULL, PRIMARY KEY (`id`), KEY `product_id` (`product_id`) );
このうち、products
テーブルは、製品名や価格などの製品の基本情報を格納するために使用されます。 #product_variants テーブルが使用されます。属性名と値、SKU コード、在庫数量など、製品の複数の仕様情報を保存するために使用されます。
// 定义商品模型类 class Product extends IlluminateDatabaseEloquentModel { // 定义与多规格SKU的关联关系 public function variants() { return $this->hasMany('ProductVariant'); } } // 定义多规格SKU模型类 class ProductVariant extends IlluminateDatabaseEloquentModel { // 定义与商品的关联关系 public function product() { return $this->belongsTo('Product'); } }
<!-- 商品详情页面 --> <h1>{{ $product->name }}</h1> <p>价格:{{ $product->price }}</p> <!-- 多规格SKU信息 --> <h2>多规格SKU</h2> @foreach ($product->variants as $variant) <p>属性1:{{ $variant->attribute_1 }}</p> <p>属性2:{{ $variant->attribute_2 }}</p> <p>属性3:{{ $variant->attribute_3 }}</p> <p>SKU:{{ $variant->sku }}</p> <p>库存:{{ $variant->stock }}</p> @endforeach
// 定义商品控制器类 class ProductController extends IlluminateRoutingController { public function calculatePrice(Request $request) { $product = Product::find($request->input('product_id')); $variant = ProductVariant::find($request->input('variant_id')); $price = $product->price + $variant->price; return response()->json(['price' => $price]); } }
以上がPHP コーディングの実践: 製品のマルチ仕様 SKU 機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。