[回馈]ASP.NET Core MVC开发实战之商城系统(四)

简介: 经过一段时间的准备,新的一期【ASP.NET Core MVC开发实战之商城系统】已经开始,在之前的文章中,讲解了商城系统的整体功能设计,页面布局设计,环境搭建,系统配置,及首页【商品类型,banner条,友情链接,降价促销,新品爆款】,商品列表页面等功能的开发,今天继续讲解商品详情功能开发,仅供学习分享使用,如有不足之处,还请指正。

经过一段时间的准备,新的一期【ASP.NET Core MVC开发实战之商城系统】已经开始,在之前的文章中,讲解了商城系统的整体功能设计,页面布局设计,环境搭建,系统配置,及首页【商品类型,banner条,友情链接,降价促销,新品爆款】,商品列表页面等功能的开发,今天继续讲解商品详情功能开发,仅供学习分享使用,如有不足之处,还请指正。

 

商品详情功能说明

 

首页和商品列表,都是只展示商品的主要信息,如商品名称,商品价格,类型等内容,让人有一个先入为主的商品概念,当用户对商品有兴趣时,可以点击链接跳转商品详情页面,查看商品更全面的信息,如:颜色,尺寸等内容。

 

商品详情功能设计

 

根据商品详情页面功能说明,在此页面,用户可以查看商品的具体内容,如:图片,颜色,大小,类型,标签以及加入购物车,立即购买等功能,具体页面设计如下所示:

 

商品详情页面功能开发

 

商品详情主要展示商品信息和商品配置信息。

 

1. 数据表创建

 

关于商品表EB_Product和对应模型Product的创建,可参考第二篇文章。商品配置表EB_ProductConfig,主要配置商品的特殊属性,如:颜色,尺寸,缩略图等内容,如下所示:

创建表的语句,如下所示:

CREATETABLE[dbo].[EB_ProductConfig]([Id][bigint] IDENTITY(1,1)NOTNULL,[ProductId][bigint]NULL,[ConfigType][varchar](50)NULL,[ConfigName][varchar](50)NULL,[ConfigValue][varchar](150)NULL,[CreateTime][datetime]NULL,[CreateUser][varchar](50)NULL,[LastEditTime][datetime]NULL,[LastEditUser][varchar](50)NULL)ON[PRIMARY]

 

2. 商品配置实体创建

 

商品配置表对应的项目模型实体,和数据表一一对应,如下所示:

namespaceEasyBuyShop.Models{
/// <summary>/// 产品配置,主要配置颜色,大小,缩略图路径等/// </summary>    [SqlSugar.SugarTable("EB_ProductConfig")]
publicclassProductConfig : EntityModel    {
publiclongProductId { get; set; }
publicstringConfigType { get; set; }
publicstringConfigName { get; set; }
publicstringConfigValue { get; set; }
    }
}

 

3. 数据处理层DAL

 

商品详情页面主要根据商品ID获取商品的详细信息以及商品配置信息,如下所示:

商品详细信息在ProductDal中,如下所示:

publicProductGetProduct(longId)
{
try    {
using (vardb=this.GetDb(BaseDal.ConnStr))
        {
returndb.Queryable<Product>().First(r=>r.Id==Id);
        }
    }
catch (Exceptionex)
    {
LogHelper.Fatal(ex.Message);
returnnull;
    }
}

商品配置信息在ProductConfigDal中,获取配置信息如下所示:

usingEasyBuyShop.Models;
usingEasyBuyShop.Utils;
namespaceEasyBuyShop.DAL{
publicclassProductConfigDal : BaseDal    {
publicProductConfigDal()
        {
        }
/// <summary>/// 获取产品配置/// </summary>/// <param name="productId"></param>/// <returns></returns>publicList<ProductConfig>GetProductConfigListById(longproductId)
        {
try            {
using (vardb=this.GetDb(BaseDal.ConnStr))
                {
returndb.Queryable<ProductConfig>().Where(r=>r.ProductId==productId).ToList();
                }
            }
catch (Exceptionex)
            {
LogHelper.Fatal(ex.Message);
returnnewList<ProductConfig>();
            }
        }
    }
}

 

4. 控制器获取

 

商品详细信息在ProductController的Detail方法中,根据传入的ID进行读取,如下所示:

publicIActionResultDetail(intId)
{
varusername=HttpContext.Session.GetString("username");
varrealName=HttpContext.Session.GetString("realname");
ViewData["Username"] =username;
ViewData["RealName"] =realName;
ProductDalproductDal=newProductDal();
ProductConfigDalproductConfigDal=newProductConfigDal();
varproduct=productDal.GetProduct(Id);
varproductConfigList=productConfigDal.GetProductConfigListById(Id);
ViewData["ProductConfigList"]=productConfigList;
ViewData["Product"] =product;
returnView();
}

将获取到的Product对象和ProductConfigList列表对象通过ViewData传递到View视图层中进行展示。

 

5. 视图层展示

 

在Views/Product/Detail.cshtml中,接收控制器方法传递的数据,并进行展示。如下所示:

@{
    ViewData["Title"] = "商品详情";
}
@{
    var product = ViewData["Product"] as Product;
    var productConfigList = ViewData["ProductConfigList"] as List<ProductConfig>;
}
<divclass=""><formmethod="post"id="detailForm"><inputtype="hidden"name="productId"value="@(product.Id)"/><inputtype="hidden"name="color"id="color"value=""/><inputtype="hidden"name="size"id="size"value=""/><!-- quick view start --><divclass="container"><divclass="row"><divid="view-gallery"><divclass="col-xs-12"><divclass="d-table"style="width:100%"><divclass="d-tablecell"><divclass="main-view modal-content"><divclass="row"><divclass="col-xs-12 col-sm-5"><divclass="quick-image"><divclass="single-quick-image tab-content text-center">                                                    @{
                                                        var productConfigImages = productConfigList.Where(r => r.ConfigType == "Image").ToList();
                                                        for (int i = 0; i <productConfigImages.Count;i++){varproductConfigImage = productConfigImages[i];<div class="tab-pane  fade in @(i==0?"active":"")" id="sin-pro-@(i)"><imgsrc="@(productConfigImage.ConfigValue)"alt=""></div>                                                        }
                                                    }
</div><divclass="quick-thumb"><divclass="nav nav-tabs"><ulstyle="padding-left:0px;">                                                            @{
                                                                for (int i = 0; i <productConfigImages.Count;i++){varproductConfigImage = productConfigImages[i];<li><adata-toggle="tab"href="##"onclick="javascript:tabProductImage('sin-pro-@(i)',this);"><imgsrc="@(productConfigImage.ConfigName)"alt="quick view"style="width:90px;height:90px;"></a></li>                                                                }
                                                            }
</ul></div></div></div></div><divclass="col-xs-12 col-sm-7"><divclass="quick-right"><divclass="quick-right-text"><h3><strong>@product.Name</strong></h3><divclass="rating"><iclass="fa fa-star"></i><iclass="fa fa-star"></i><iclass="fa fa-star"></i><iclass="fa fa-star-half-o"></i><iclass="fa fa-star-o"></i></div><divclass="amount"><h4>$@product.PreferentialPrice</h4></div><p>@product.Description</p><divclass="row m-p-b"><divclass="col-sm-12"><divclass="por-dse responsive-strok clearfix"><ul><li><span>是否现货</span><strong>:</strong> 现货</li><li><span>是否新品</span><strong>:</strong> 新品</li><li><span>商品类型</span><strong>:</strong><ahref="">@product.BasicStyle</a><ahref="">@product.ProductStyle</a></li></ul></div></div></div><divclass="row m-p-b"><divclass="col-sm-12"><divclass="por-dse color"><ul><li><span>颜色分类</span><strong>:</strong><divclass="por-dsc-div">                                                                            @{
                                                                                var productColors = productConfigList.Where(r => r.ConfigType == "Color").ToList();
                                                                                for (int i = 0; i <productColors.Count;i++){<span class="por-dsc-span" onclick="javascript:checkActive(this,'color');">@(productColors[i].ConfigValue)</span>                                                                                }
                                                                            }
</div></li><li><span>大小</span><strong>:</strong><divclass="por-dsc-div">                                                                            @{
                                                                                var productSizes = productConfigList.Where(r => r.ConfigType == "Size").ToList();
                                                                                for (int i = 0; i <productSizes.Count;i++){<span class="por-dsc-span" onclick="javascript:checkActive(this,'size');">@(productSizes[i].ConfigValue)</span>                                                                                }
                                                                            }
</div></li><li><span>标签</span><strong>:</strong><ahref="">@product.BasicStyle</a><ahref="">@product.ProductStyle</a></li></ul></div></div></div><divclass="dse-btn"><divclass="row"><divclass="col-sm-12 col-md-12"><divclass="por-dse clearfix"><ul><liclass="share-btn clearfix"><span>数量</span><inputclass="input-text qty"name="quantity"maxlength="12"value="1"title="数量"type="text"></li></ul></div></div><divclass="col-sm-12 col-md-12"><divclass="por-dse add-to"style="display:inline-block"><ahref="##"onclick="javascript:addCartByForm();">加入购物车</a></div><divclass="por-dse add-to"style="display:inline-block"><ahref="##"onclick="javascript:addPurchaseByForm();">立即购买</a></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div><!-- quick view end --></form></div><scriptsrc="~/js/shop.js"></script>

 

商品详情页面展示

 

运行程序,在首页或商品列表页面,点击商品链接,进入商品详情页面,如下所示:

以上就是ASP.NET Core MVC开发实战之商城系统第四部分内容,后续将继续介绍其他模块,敬请期待。

相关文章
|
1月前
|
开发框架 .NET 开发者
简化 ASP.NET Core 依赖注入(DI)注册-Scrutor
Scrutor 是一个简化 ASP.NET Core 应用程序中依赖注入(DI)注册过程的开源库,支持自动扫描和注册服务。通过简单的配置,开发者可以轻松地从指定程序集中筛选、注册服务,并设置其生命周期,同时支持服务装饰等高级功能。适用于大型项目,提高代码的可维护性和简洁性。仓库地址:&lt;https://github.com/khellang/Scrutor&gt;
48 5
|
3月前
|
存储 开发框架 JSON
ASP.NET Core OData 9 正式发布
【10月更文挑战第8天】Microsoft 在 2024 年 8 月 30 日宣布推出 ASP.NET Core OData 9,此版本与 .NET 8 的 OData 库保持一致,改进了数据编码以符合 OData 规范,并放弃了对旧版 .NET Framework 的支持,仅支持 .NET 8 及更高版本。新版本引入了更快的 JSON 编写器 `System.Text.UTF8JsonWriter`,优化了内存使用和序列化速度。
105 0
|
17天前
|
开发框架 搜索推荐 算法
一个包含了 50+ C#/.NET编程技巧实战练习教程
一个包含了 50+ C#/.NET编程技巧实战练习教程
67 18
|
2月前
|
开发框架 .NET C#
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
50 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
|
1月前
|
开发框架 缓存 .NET
GraphQL 与 ASP.NET Core 集成:从入门到精通
本文详细介绍了如何在ASP.NET Core中集成GraphQL,包括安装必要的NuGet包、创建GraphQL Schema、配置GraphQL服务等步骤。同时,文章还探讨了常见问题及其解决方法,如处理复杂查询、错误处理、性能优化和实现认证授权等,旨在帮助开发者构建灵活且高效的API。
34 3
|
17天前
|
开发框架 算法 中间件
ASP.NET Core 中的速率限制中间件
在ASP.NET Core中,速率限制中间件用于控制客户端请求速率,防止服务器过载并提高安全性。通过`AddRateLimiter`注册服务,并配置不同策略如固定窗口、滑动窗口、令牌桶和并发限制。这些策略可在全局、控制器或动作级别应用,支持自定义响应处理。使用中间件`UseRateLimiter`启用限流功能,并可通过属性禁用特定控制器或动作的限流。这有助于有效保护API免受滥用和过载。 欢迎关注我的公众号:Net分享 (239字符)
36 0
|
2月前
|
消息中间件 开发框架 .NET
.NET 8 强大功能 IHostedService 与 BackgroundService 实战
【11月更文挑战第7天】本文介绍了 ASP.NET Core 中的 `IHostedService` 和 `BackgroundService` 接口及其用途。`IHostedService` 定义了 `StartAsync` 和 `StopAsync` 方法,用于在应用启动和停止时执行异步操作,适用于资源初始化和清理等任务。`BackgroundService` 是 `IHostedService` 的抽象实现,简化了后台任务的编写,通过 `ExecuteAsync` 方法实现长时间运行的任务逻辑。文章还提供了创建和注册这两个服务的实战步骤,帮助开发者在实际项目中应用这些功能。
|
3月前
|
开发框架 NoSQL MongoDB
C#/.NET/.NET Core开发实战教程集合
C#/.NET/.NET Core开发实战教程集合
|
3月前
mcr.microsoft.com/dotnet/core/aspnet:2.1安装libgdiplus
mcr.microsoft.com/dotnet/core/aspnet:2.1安装libgdiplus
40 1
|
4月前
|
开发框架 监控 前端开发
在 ASP.NET Core Web API 中使用操作筛选器统一处理通用操作
【9月更文挑战第27天】操作筛选器是ASP.NET Core MVC和Web API中的一种过滤器,可在操作方法执行前后运行代码,适用于日志记录、性能监控和验证等场景。通过实现`IActionFilter`接口的`OnActionExecuting`和`OnActionExecuted`方法,可以统一处理日志、验证及异常。创建并注册自定义筛选器类,能提升代码的可维护性和复用性。