Blazor中@bind双向绑定怎么使用

来源:网站建设作者:美园和花头衔:网络博主
导读:本期聚焦于小伙伴创作的《Blazor中@bind双向绑定怎么使用》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《Blazor中@bind双向绑定怎么使用》有用,将其分享出去将是对创作者最好的鼓励。

Blazor的@bind指令用于实现视图和数据的双向绑定,当数据发生变化时视图会自动更新,用户在视图上的操作也会同步修改对应的数据源,是Blazor前端开发中非常常用的功能。

Blazor中@bind双向绑定怎么使用

@bind基础绑定用法

最基础的@bind用法是绑定组件的普通属性,比如绑定一个字符串类型的变量,当输入框内容变化时,绑定的变量会同步更新。

@page "/bind-demo"

<h3>基础双向绑定示例</h3>
<p>输入的内容:@UserName</p>
<input @bind="UserName" />

@code {
    public string UserName { get; set; } = "默认名称";
}

上面的代码中,输入框和UserName属性实现了双向绑定,修改输入框内容后,上方的段落会同步显示最新的UserName值。

绑定指定事件

默认情况下@bind绑定的是onchange事件,也就是输入框失去焦点时才会更新数据源,如果需要实时更新,可以指定绑定的事件为oninput。

@page "/bind-event-demo"

<h3>指定绑定事件示例</h3>
<p>实时输入的内容:@InputContent</p>
<input @bind="InputContent" @bind:event="oninput" />

@code {
    public string InputContent { get; set; } = "";
}

这里通过@bind:event="oninput"指定了绑定输入事件,输入框内容每变化一次,InputContent就会立即更新。

绑定组件属性

@bind也可以用于绑定子组件的属性,实现父子组件之间的双向数据同步,子组件需要定义对应的属性和事件回调。

首先定义子组件CustomInput.razor

<input value="@Value" @oninput="OnInput" />

@code {
    [Parameter]
    public string Value { get; set; }

    [Parameter]
    public EventCallback<string> ValueChanged { get; set; }

    private async Task OnInput(ChangeEventArgs e)
    {
        var newValue = e.Value?.ToString() ?? "";
        await ValueChanged.InvokeAsync(newValue);
    }
}

父组件中使用该子组件并绑定属性:

@page "/parent-demo"

<h3>组件双向绑定示例</h3>
<p>绑定的值:@ParentValue</p>
<CustomInput @bind-Value="ParentValue" />

@code {
    public string ParentValue { get; set; } = "初始值";
}

子组件的属性名是Value,对应的事件回调必须命名为ValueChanged,父组件使用@bind-Value就可以实现双向绑定,修改子组件的输入框内容,父组件的ParentValue会同步更新。

@bind和@bind-value的区别

很多开发者会混淆@bind和@bind-value的用法,两者的核心区别在于绑定的属性不同:

  • @bind="PropertyName"是绑定组件的Value属性,等价于@bind-value="PropertyName",是简写形式
  • 如果需要绑定组件的非Value属性,就需要使用@bind-属性名="PropertyName"的格式,比如绑定子组件的Title属性:@bind-Title="TitleValue"

自定义双向绑定格式

如果需要处理特殊格式的双向绑定,比如日期格式化,可以通过@bind:format指定格式。

@page "/format-demo"

<h3>日期格式化绑定示例</h3>
<p>选择的日期:@SelectDate</p>
<input type="date" @bind="SelectDate" @bind:format="yyyy-MM-dd" />

@code {
    public DateTime SelectDate { get; set; } = DateTime.Now;
}

上面的代码指定了日期的显示格式为yyyy-MM-dd,输入框会按照该格式显示和解析日期内容。

注意事项

  • 绑定的属性必须是公开的,并且有对应的get和set访问器,否则无法实现双向绑定
  • 子组件实现双向绑定时,事件回调的参数类型必须和属性的类型一致,否则会报错
  • 不要在绑定属性的set访问器中做复杂的耗时操作,避免影响视图更新性能

Blazor@bind双向绑定组件通信修改时间:2026-06-20 02:48:26

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。