AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题 / 76979736
Accepted
Michael Schreiber
Michael Schreiber
Asked: 2023-08-26 02:27:08 +0800 CST2023-08-26 02:27:08 +0800 CST 2023-08-26 02:27:08 +0800 CST

在输入中输入值后,Blazor 与文本输入的绑定不起作用

  • 772

我的要求是有一个文本输入,用户可以在其中输入文本,但也可以以其他方式设置其值(例如,通过按钮)。我在 blazor 服务器项目中使用 .Net 7。我创建了以下简单的 UI 来重现我在更复杂的构造中遇到的问题: 简单的用户界面

剃须刀代码:

Text Input:
<input type="text" @bind-Value=Value @bind-Value:event="oninput" />
<br />
<button class="btn btn-primary" @onclick="IncrementCounter">Increment Counter and set Value </button>
<br />
Current Value: @Value
<br />
Current Counter Value: @_counter

C# 代码:

@code {
    private int _counter = 1000;

    private string? Value { get; set; }

    private void IncrementCounter()
    {
        _counter++;
        Value = _counter.ToString();
    }
}

当我单击按钮时,文本输入中的值将按预期设置。即,它被设置为计数器的当前值并且计数器递增。当我在文本输入中输入某些内容时,该值会显示在按钮下方(“当前值”)。但是,现在该按钮不再更新文本输入的内容。的纯文本@Value仍然显示该Value属性已按预期设置。从文本输入到Value属性的绑定仍然有效,但反之则不然。任何如何解决这个问题的想法都非常受欢迎。

我试过:

  • INotifyPropertyChanged为财产实施Value。
  • StateHasChanged内调用IncrementCounter()。
  • 致电酒店StateHasChanged内Value。
  • StateHasChanged通过另一个按钮呼叫。
  • 另一个示例,其中文本输入位于Value带有Parameter. 在此示例中,我还实现了一个ValueChanged EventCallback.

什么都没起作用。

抱歉,我当时很绝望。

blazor
  • 2 2 个回答
  • 19 Views

2 个回答

  • Voted
  1. Best Answer
    RBee
    2023-08-26T03:15:29+08:002023-08-26T03:15:29+08:00

    您需要使用@bind-value(小写“v”)或@bind单独使用。

    <input type="text" @bind-value=Value @bind-value:event="oninput" />
    <input type="text" @bind=Value @bind:event="oninput" />
    

    布拉佐小提琴

    • 1
  2. MrC aka Shaun Curtis
    2023-08-26T04:40:49+08:002023-08-26T04:40:49+08:00

    作为@RBee 答案的补充,您可以取消文本转换代码并直接绑定到计数器。

    当 Razor 编译器将绑定功能构建到生成的 C# 组件类中时,它将在幕后实现必要的转换代码。

    @page "/"
    
    <PageTitle>Index</PageTitle>
    
    <div class="p-2 mb-3">
        <label class="label">
            Counter Input:
        </label>
        <input class="form-control" type="number" @bind="_counter" @bind:event="oninput" />
    </div>
    <div class="mb-3 text-end">
        <button class="btn btn-primary" @onclick="IncrementCounter">Increment Counter and set Value </button>
    </div>
    
    <div class="bg-dark text-white m-2 p-2">
        <pre>Current Counter Value: @_counter</pre>
    </div>
    
    @code {
        @code {
            private int _counter = 1000;
    
            private void IncrementCounter()
            {
                _counter++;
            }
        }
    }
    
    • 0

相关问题

  • 具有组件到组件数据传递的 Blazor 页面在加载时引发事件错误

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    使用 <font color="#xxx"> 突出显示 html 中的代码

    • 2 个回答
  • Marko Smith

    为什么在传递 {} 时重载解析更喜欢 std::nullptr_t 而不是类?

    • 1 个回答
  • Marko Smith

    您可以使用花括号初始化列表作为(默认)模板参数吗?

    • 2 个回答
  • Marko Smith

    为什么列表推导式在内部创建一个函数?

    • 1 个回答
  • Marko Smith

    我正在尝试仅使用海龟随机和数学模块来制作吃豆人游戏

    • 1 个回答
  • Marko Smith

    java.lang.NoSuchMethodError: 'void org.openqa.selenium.remote.http.ClientConfig.<init>(java.net.URI, java.time.Duration, java.time.Duratio

    • 3 个回答
  • Marko Smith

    为什么 'char -> int' 是提升,而 'char -> Short' 是转换(但不是提升)?

    • 4 个回答
  • Marko Smith

    为什么库中不调用全局变量的构造函数?

    • 1 个回答
  • Marko Smith

    std::common_reference_with 在元组上的行为不一致。哪个是对的?

    • 1 个回答
  • Marko Smith

    C++17 中 std::byte 只能按位运算?

    • 1 个回答
  • Martin Hope
    fbrereto 为什么在传递 {} 时重载解析更喜欢 std::nullptr_t 而不是类? 2023-12-21 00:31:04 +0800 CST
  • Martin Hope
    比尔盖子 您可以使用花括号初始化列表作为(默认)模板参数吗? 2023-12-17 10:02:06 +0800 CST
  • Martin Hope
    Amir reza Riahi 为什么列表推导式在内部创建一个函数? 2023-11-16 20:53:19 +0800 CST
  • Martin Hope
    Michael A fmt 格式 %H:%M:%S 不带小数 2023-11-11 01:13:05 +0800 CST
  • Martin Hope
    God I Hate Python C++20 的 std::views::filter 未正确过滤视图 2023-08-27 18:40:35 +0800 CST
  • Martin Hope
    LiDa Cute 为什么 'char -> int' 是提升,而 'char -> Short' 是转换(但不是提升)? 2023-08-24 20:46:59 +0800 CST
  • Martin Hope
    jabaa 为什么库中不调用全局变量的构造函数? 2023-08-18 07:15:20 +0800 CST
  • Martin Hope
    Panagiotis Syskakis std::common_reference_with 在元组上的行为不一致。哪个是对的? 2023-08-17 21:24:06 +0800 CST
  • Martin Hope
    Alex Guteniev 为什么编译器在这里错过矢量化? 2023-08-17 18:58:07 +0800 CST
  • Martin Hope
    wimalopaan C++17 中 std::byte 只能按位运算? 2023-08-17 17:13:58 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve