在 Blazor Server 或 Blazor WebAssembly(.NET 8+)中,[SupplyParameterFromForm]
并不是 .NET 8 原生支持的特性 —— 它并不存在于官方 API 中。 很可能你混淆了以下两个概念:
1. [SupplyParameterFromQuery]
和 [SupplyParameterFromRoute]
这是 .NET 8 中真实存在的、用于组件参数绑定的特性,但仅支持从 URL 查询字符串或路由参数注入,不支持 HTML 表单提交(POST body)。
[SupplyParameterFromQuery]:从 URL 查询参数(如
?name=John&age=25)自动填充组件参数
[SupplyParameterFromRoute]:从路由模板(如
/user/{id:int})提取值
二者都只适用于 @page组件(即路由组件),且仅作用于 GET 请求上下文
2. 表单数据处理的正确方式:使用 EditForm
+ Input*
组件 + 模型绑定
Blazor 中处理表单(尤其是 POST 场景)的标准做法是:不依赖参数特性,而是用 EditForm
绑定一个模型对象,并在 OnValidSubmit
中处理提交逻辑。
UserInput),包含属性和验证特性(可选) 在组件中声明该模型实例,并传给
<editform model="@model"></editform>用
<inputtext></inputtext>、
<inputnumber></inputnumber>等子组件绑定字段 提交时,模型属性已由框架自动更新,直接使用即可
示例:
<EditForm Model="@user" OnValidSubmit="HandleValidSubmit">
<InputText @bind-Value="user.Name" />
<InputNumber @bind-Value="user.Age" />
<button type="submit">提交</button>
</EditForm>
<p>@code {
private UserInput user = new();</p><pre class='brush:php;toolbar:false;'>private void HandleValidSubmit()
{
// 此时 user.Name 和 user.Age 已被表单自动更新
Console.WriteLine($"收到:{user.Name}, {user.Age}");
}
public class UserInput
{
public string? Name { get; set; }
public int Age { get; set; }
}}
3. 如果你真想“从表单 POST 中解析参数”,需手动处理(非常规)
Blazor 本身不提供类似 MVC 的
[FromBody]或
[FromForm]绑定机制。若后端需接收传统表单(
application/x-www-form-urlencoded),可: 用普通 HTML
<form method="post" action="/api/submit"></form>提交到控制器(绕过 Blazor 渲染管线) 或在 Blazor 组件中用
HttpClient手动构造表单数据并 POST 服务端控制器用
[FromForm]接收(ASP.NET Core 标准行为)
但这已脱离 Blazor 组件参数绑定范畴,不属于
[SupplyParameterFrom...]的设计目标。
基本上就这些 —— 别找
[SupplyParameterFromForm],它不存在;用好
EditForm就够了。
