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 / 问题 / 77675023
Accepted
David Thielen
David Thielen
Asked: 2023-12-17 23:45:14 +0800 CST2023-12-17 23:45:14 +0800 CST 2023-12-17 23:45:14 +0800 CST

Blazor 如何知道何时查找参数更改

  • 772

假设我有以下两个组合框(都是伪代码):

<ComboBox Data="@AllLastNames" @bind-Value="@LastName"/>
<ComboBox Data="@AllFirstNames" @bind-Value="@FirstName"/>

背后的代码是:

private string LastName { get; set; }
private string FirstName { get; set; }

private List<string> AllLastNames => _allLastNames;
private List<string> AllFirstNames => _firstNameDictionary[LastName];

好的,如果在适当的时间获得大餐,则以上所有功能都可以很好地工作AllFirstNames,请看到它通过参考平等比较而变化,并SetParameteraAsync()用新值调用。

那么,何时/为什么以及如何决定检查该Data=属性以查看它们是否已更改?

LastName这是我应该打电话的情况吗StateHasChanged()?

blazor
  • 4 4 个回答
  • 46 Views

4 个回答

  • Voted
  1. abberdeen
    2023-12-18T01:04:45+08:002023-12-18T01:04:45+08:00

    Blazor 决定更新状态的方式和原因可以被视为魔法或黑匣子(更多有关状态的信息)。

    但如果您对它的工作原理感兴趣,我可以举出以下示例。

    状态会自动更新:

    • 在 Blazor 事件处理程序上(@onclick、@bind- 等)
    • 关于组件生命周期事件(OnInitialized、OnParametersSet、ShouldRender、OnAfterRender等)
    • 关于 Razor 标记更新

    您需要手动更新状态:

    • 异步操作(从API、数据库、文件等接收数据)
    • 非 Blazor 事件
    • 与 JavaScript 互操作

    在您的情况下,@bind-Value="@LastName"作为自动更新状态的触发器,例如,当用户选择 中的项目时ComboBox AllLastNames,整个链都会更新,即LastName,AllFirstNames并且ComboBox AllFirstNames无需调用StateHasChanged。

    注:这是我个人的偏好,但根据我的经验,使用字典而不检查存在性检查可能会导致错误,并且通常很难找到来源。

    我建议检查是否存在(即使您确定它存在):

    private List<string> AllFirstNames => _firstNameDictionary.TryGetValue(LastName, out var firstNames) ? firstNames : new List<string>();
    
    • 1
  2. MrC aka Shaun Curtis
    2023-12-18T06:54:14+08:002023-12-18T06:54:14+08:00

    不涉及黑魔法。

    当渲染实例化组件时,它会创建并维护该组件的映射属性列表。当它调用时,它会ParameterView从此列表中生成对象SetParametersAsync。

    当渲染器渲染组件时,它会检查以确定任何子组件参数的状态是否已更改。如果有,它会调用SetParametersAsync子组件。

    注意我声明:“它调用SetParametersAsync”,而不是“它呈现组件”。如果该组件是一个ComponentBase组件,那么它就会。还有其他第三方组件库组件可能会覆盖SetParametersAsync并实现不触发StateHasChanged.

    应用于每个值以检测变化的算法如下:

    public static bool MayHaveChanged<T1, T2>(T1 oldValue, T2 newValue)
    {
        var oldIsNotNull = oldValue != null;
        var newIsNotNull = newValue != null;
    
        // Only one is null so different
        if (oldIsNotNull != newIsNotNull)
            return true;
    
        var oldValueType = oldValue!.GetType();
        var newValueType = newValue!.GetType();
    
        // HERE
        if (oldValueType != newValueType)
            return true;
    
        if (!IsKnownImmutableType(oldValueType))
            return true;
    
        return !oldValue.Equals(newValue);
    }
    
    private static bool IsKnownImmutableType(Type type)
        => type.IsPrimitive
            || type == typeof(string)
            || type == typeof(DateTime)
            || type == typeof(Type)
            || type == typeof(decimal)
            || type == typeof(Guid);
    

    基本上它可以检测基元和一些值对象的变化。对于其他一切MayHaveChanged都会返回true[没有机会]。注意回调和 RenderFragments 是引用对象,因此 return true。

    在您的情况下List<string> AllLastNames是引用类型,因此测试失败并MayHaveChanged返回true。因此,如果父组件进行ComboBox渲染,则渲染器将SetParametersAsync调用ComboBox.

    • 1
  3. J S
    2023-12-17T23:52:04+08:002023-12-17T23:52:04+08:00

    将事件处理程序EG ONCHANGE添加到您的ComboBox,该combobox将使用数据库或您正在使用的其他来源更新参考列表

    • 0
  4. Best Answer
    ℍ ℍ
    2023-12-18T01:24:15+08:002023-12-18T01:24:15+08:00

    那么 Blazor 何时/为何以及如何决定检查 Data= 属性以查看它们是否已更改?

    每次渲染此组件时,都会在 LastName 更改时发生。

    Data="@AllFirstNames"是 Blazor 中的“复杂参数”,这意味着它将始终被视为已更改。

    • 0

相关问题

  • 如何在 EditForm Blazor 组件内获取 SfListView 模板的正确上下文?

  • Blazor - 清除所有选择选项而不重新获取数据

  • 在 Blazor WASM 中操作 index.html

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

  • 具有组件到组件数据传递的 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