Blazor 怎么实现一个简单的购物车

购物车数据模型设计包含CartItem类和CartService服务:CartItem含ID、名称、单价、数量字段;CartService用List存储并提供增删改查及总价计算,注册为Scoped服务,在组件中注入使用,支持数量合并、实时UI更新。

blazor 怎么实现一个简单的购物车

购物车数据模型设计

先定义一个商品项(CartItem)类,包含 ID、名称、单价、数量等基本字段:

public class CartItem
{
    public int Id { get; set; }
    public string Name { get; set; } = string.Empty;
    public decimal Price { get; set; }
    public int Quantity { get; set; } = 1;
}

再建一个购物车服务(CartService),用 List 存储当前商品,提供添加、更新、删除、清空和计算总价的方法。推荐注册为 Scoped 服务,确保同一页面会话内共享状态。

注册并注入购物车服务

Program.cs 中添加服务:

// Program.cs
builder.Services.AddScoped();

然后在需要显示购物车的组件(如 Cart.razorProductList.razor)中用 @inject CartService Cart 注入使用。

添加商品到购物车

在商品列表页,每个商品旁放一个“加入购物车”按钮,点击时调用服务方法:


@inject CartService Cart

@foreach (var product in products)
{
    

        @product.Name – ¥@product.Price
        
    

}

注意:如果想支持重复添加同一商品时合并数量,AddItem 方法内部应先查找是否存在相同 ID 的项,有则 Quantity++,否则追加新项。

购物车页面展示与交互

新建 Cart.razor 页面,遍历 Cart.Items 渲染列表,并提供增减数量、删除单个、清空等操作:

@foreach (var item in Cart.Items) 循环渲染每项数量输入框绑定 @bind="item.Quantity",配合 @onchange 调用 Cart.UpdateQuantity(item.Id, item.Quantity)“−”按钮调用 Cart.RemoveItem(item.Id),“×”删除整条底部显示 Cart.TotalPrice(自动计算:sum of item.Price * item.Quantity)加 @ref="cartState" + Cart.OnChange += StateHasChanged 可让界面响应服务变化(或更推荐:在 CartService 中继承 INotifyPropertyChanged,配合 @bind 自动刷新)

基本上就这些。不复杂但容易忽略的是状态同步时机——Blazor Server 需要确保 UI 在服务变更后及时重绘,建议在 CartService 的所有修改方法末尾调用 NotifyStateChanged() 并在组件中订阅该事件触发 StateHasChanged()

以上就是Blazor 怎么实现一个简单的购物车的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1443182.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 19:50:00
下一篇 2025年12月14日 20:07:10

相关推荐

  • Blazor 动态修改 CSS 自定义属性的方法

    Blazor中动态修改CSS自定义属性需通过JS Interop调用style.setProperty(),全局变量设在document.documentElement,局部变量作用于ElementReference;需手动调用StateHasChanged响应逻辑变化,并注意SSR兼容性与性能优化…

    2025年12月17日
    000
  • WinForms怎么美化UI界面 WinForms第三方UI库使用教程

    WinForms可通过启用视觉样式、引入第三方UI库及局部美化实现现代化UI。需在Main方法开头调用Application.EnableVisualStyles();推荐NuGet安装SunnyUI、MaterialSkin.2或IrisSkins;再统一字体、调整配色、添加背景图;自定义绘制时须…

    2025年12月17日
    000
  • Blazor RenderTreeBuilder 动态UI生成教程

    RenderTreeBuilder 是 Blazor 底层 UI 构建机制,专为框架作者和高级场景设计,日常开发应优先使用 @bind、RenderFragment 等标准方式;仅在实现动态表单引擎、虚拟滚动、自定义渲染器等深度定制场景才建议使用。 Blazor 的 RenderTreeBuilde…

    2025年12月17日
    000
  • WPF怎么改变控件样式 WPF Style和Template使用方法

    WPF中样式控制分Style(设外观属性)和ControlTemplate(重定义结构),Style通过Setter和Trigger统一配置,ControlTemplate用ContentPresenter和VisualStateManager自定义布局与状态,二者配合实现可复用、易维护的统一界面。…

    2025年12月17日
    000
  • WinForms中如何实现自定义控件的绘制?

    答案:自定义控件绘制需重写OnPaint方法,利用Graphics对象进行绘图,并通过Invalidate()触发重绘;性能优化包括启用双缓冲、局部刷新、缓存绘制结果及避免频繁创建GDI对象;用户交互通过处理鼠标键盘事件改变控件状态并触发重绘实现;结合GraphicsPath、变换、渐变等GDI+高…

    2025年12月17日
    000
  • WPF中的矢量图形绘制怎么实现?

    WPF实现矢量图形绘制主要依赖其硬件加速的保留模式渲染引擎,通过Shape类或DrawingContext进行图形操作。与GDI+的立即模式、CPU渲染不同,WPF基于视觉树和DirectX,实现高效、清晰的矢量渲染,支持缩放不失真。对于简单图形,使用Rectangle、Ellipse等Shape对…

    2025年12月17日
    000
  • 如何用C#代码控制WinForms控件的透明度?

    答案:WinForms中窗体透明度通过Opacity属性实现,子控件背景透明则使用Color.FromArgb或BackColor=Color.Transparent。具体为:1. Form的Opacity属性(0-1.0)控制整体透明度;2. TransparencyKey使特定颜色区域完全透明,…

    2025年12月17日
    000
  • WPF中的布局容器有哪些区别与选择?

    WPF布局容器的核心是“内容优先、职责分离”的设计哲学,通过Measure和Arrange两阶段实现父子容器间的布局协商。Grid提供灵活的二维网格布局,适合复杂响应式设计;StackPanel按线性堆叠元素,适用于简单列表;DockPanel支持边缘停靠,常用于框架布局;WrapPanel实现流式…

    2025年12月17日
    000
  • WinForms的TableLayoutPanel布局技巧有哪些?

    答案:TableLayoutPanel通过RowStyles和ColumnStyles的SizeType(Absolute、AutoSize、Percent)实现自适应布局,结合控件的Dock和Anchor属性控制填充与定位,利用SuspendLayout/ResumeLayout优化动态添加或移除…

    2025年12月17日
    000
  • WPF中的用户控件如何创建与使用?

    WPF用户控件是UI与逻辑的封装单元,通过继承UserControl将常用界面元素组合复用;创建时添加.xaml和.xaml.cs文件,在XAML中定义界面布局,后台代码中定义依赖属性(如ButtonText、ButtonCommand)以支持数据绑定和命令传递;使用时在父窗体引入命名空间后直接实例…

    2025年12月17日
    000
  • WPF中的动画效果应该怎么制作?

    WPF动画通过操纵依赖属性实现,利用声明式语法和GPU加速,以Storyboard编排动画,相比WinForms的手动重绘更高效流畅,支持路径与关键帧动画,并可通过优化渲染方式提升性能。 WPF中的动画效果,本质上是通过操纵元素的依赖属性(Dependency Properties)在一段时间内平滑…

    好文分享 2025年12月17日
    000
  • 如何实现WinForms控件的双缓冲绘制?

    最直接有效的方法是将控件的DoubleBuffered属性设置为true,可消除界面闪烁;对于复杂场景,可使用BufferedGraphicsContext和BufferedGraphics进行精细控制,先在内存中完成绘制再一次性呈现。 在WinForms中实现控件的双缓冲绘制,最直接有效的方法就是…

    2025年12月17日
    000
  • WinForms的PictureBox怎么实现缩放与滚动?

    核心是通过Matrix类对PictureBox的Image进行缩放变换,并用滚动条控制偏移实现滚动。需维护原始图像、当前缩放比例和偏移量,响应鼠标滚轮或按钮调整scale值,结合Graphics的Transform和TranslateTransform实现高效绘制。 PictureBox的缩放与滚动…

    2025年12月17日
    000
  • XML的DOM的Element接口有哪些常用方法?

    element接口是xml dom操作的核心,因它具备管理属性、操作子节点及设置内容的能力。1.属性操作方法包括getattribute()获取属性、setattribute()设置属性、hasattribute()检查属性是否存在、removeattribute()移除属性,以及attribute…

    2025年12月17日
    000
  • XML的DOM的DocumentFragment有什么用?

    documentfragment通过批量操作dom节点显著提升页面性能。它作为内存中的虚拟容器,允许开发者在不触发重绘和回流的情况下构建或修改节点结构,待所有操作完成后一次性插入文档。相较于逐个添加节点会引发多次渲染,使用documentfragment可减少浏览器的计算压力。其与普通元素节点不同之…

    2025年12月17日
    000
  • 模板渲染与数据绑定效率提升

    优化前端性能需减少计算与DOM操作,采用虚拟DOM(如React、Vue)比对变化并批量更新;合理使用key提升列表渲染效率,避免过度双向绑定,推荐单向数据流与memo缓存;结合v-if、动态import实现条件与懒加载,利用Proxy或computed精确追踪依赖,按需更新。 在现代前端开发中,模…

    2025年12月16日
    000
  • Go语言在X11环境下进行图形绘制指南

    本文详细介绍了如何使用Go语言的exp/draw/x11包在X11窗口中进行基本的图形绘制。通过创建窗口、获取屏幕图像、设置像素颜色并刷新显示,读者将掌握在X11环境下进行简单2D图形编程的核心步骤。教程包含完整的示例代码和关键注意事项,帮助开发者快速上手Go语言的X11图形应用开发。 引言 go语…

    2025年12月15日
    000
  • Go 语言在 X11 窗口中进行基础绘图

    本文详细介绍了如何使用 Go 语言的 exp/draw/x11 包在 X11 窗口中进行基础绘图。通过创建新的 X11 窗口、获取其屏幕图像、逐像素设置颜色并刷新显示,读者可以掌握在 Go 语言环境中实现简单的 2D 绘图操作。教程提供了完整的示例代码,并解释了关键步骤和注意事项,帮助开发者快速入门…

    2025年12月15日
    000
  • python使用Plotly实现动画设计

    答案:使用Plotly制作动画需组织好按时间划分的数据帧,通过go.Figure的frames参数定义每帧图形,配合sliders和play按钮实现播放控制,并设置统一坐标轴范围与过渡效果以提升流畅性。 用Python结合Plotly制作动画,关键在于理解其帧(frames)和更新逻辑。Plotly…

    2025年12月15日
    000
  • 动态修改Matplotlib图表主题的教程

    在使用matplotlib进行绘图时,`plt.style.use()`方法主要用于初始化新的图表或子图的样式。对于已渲染的图表,在运行时动态切换主题,简单地再次调用`plt.style.use()`并不会立即生效。本文将深入探讨这一限制,并提供一种通过直接修改matplotlib `figure`…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信