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 / 问题

问题[blazor-server-side](coding)

Martin Hope
Axium7
Asked: 2024-10-04 07:23:22 +0800 CST

如何在运行时更改 BlazorGoogleMaps 库中的 MapOptions?

  • 5

我正在使用 BlazorGoogleMaps NuGet 包。你可以在GitHub上查看源代码

我希望能够在执行期间将 MapType 更改为 Satellite 和 RoadMap。

以下代码没有影响。

_mapOptions.MapTypeId = MapTypeId.Satellite;
_map1.Options = _mapOptions;
//give the UI Access
await InvokeAsync(StateHasChanged);

我将此代码包含在 MapRoutes.razor.cs => AddDirections() 方法中。

谢谢

private async Task AddDirections()
{
    _durationTotalString = null;
    _distanceTotalString = null;
    if (await _dirRend.GetMap() is null)
    {
        await _dirRend.SetMap(_map1!.InteropObject);
    }

    _mapOptions.MapTypeId = MapTypeId.Satellite;
    _map1.Options = _mapOptions;
    //give the UI Access
    await InvokeAsync(StateHasChanged);

    //Adding a waypoint
    var waypoints = new List<DirectionsWaypoint>();
    waypoints.Add(new DirectionsWaypoint() { Location = "Bethlehem, PA", Stopover = true });

    //Direction Request
    var dr = new DirectionsRequest();
    dr.Origin = "Allentown, PA";
    dr.Destination = "Bronx, NY";
    dr.Waypoints = waypoints;
    dr.TravelMode = TravelMode.Driving;
    dr.DrivingOptions = new DrivingOptions()
    {
        DepartureTime = DateTime.Now.AddHours(1)
    };

    //Calculate Route
    _directionsResult = await _dirRend.Route(dr, new DirectionsRequestOptions
    {
        StripLegsStepsLatLngs = false,
        StripOverviewPath = false,
        StripOverviewPolyline = false,
        StripLegsStepsPath = false,
        StripLegsSteps = false
    });

    if (_directionsResult is null)
    {
        return;
    }
    var routes = _directionsResult.Routes.SelectMany(x => x.Legs).ToList();

    foreach (var route in routes)
    {
        _durationTotalString += route.DurationInTraffic?.Text;
        _distanceTotalString += route.Distance.Text;
    }
}
blazor-server-side
  • 1 个回答
  • 14 Views
Martin Hope
Lucas
Asked: 2024-09-22 23:28:25 +0800 CST

Blazor(.net core 8)组件从未更新

  • 5

我正在尝试定义一个充当引导警报包装器的组件。

BootstrapAlert.razor

<div class="alert alert-@AlertType d-@(string.IsNullOrEmpty(Message) ? "none" : "block")" role="alert">
    @Message
</div>

@code {
    [ParameterAttribute]
    private string AlertType { get; set; } = "info"; // Default alert type
    [ParameterAttribute]
    private string? Message { get; set; }

    // Method to update the alert type and message
    public async Task ShowAsync(string alertType, string message)
    {
        AlertType = alertType;
        Message = message;
        await InvokeAsync(StateHasChanged);
    }

    // Method to hide the alert
    public async Task HideAsync()
    {
        Message = null;
        await InvokeAsync(StateHasChanged);
    }

     protected override async Task OnParametersSetAsync()
    {
        //Message is ALWAYS null here
        await base.OnParametersSetAsync();
    }

}

页:

<form class="row" @onsubmit="SubmitForm" @onsubmit:preventDefault>
  <Alert @ref=SaveAlert></Alert>
  <button type="submit">Save</button>        
</form>

@code {
    private Alert? SaveAlert;

private async Task SubmitForm()
{
    try
    {
        await SetIsLoading(true); //DISPLAYS A LOADING SPINNER

        if (SaveAlert != null) await SaveAlert.HideAsync();

        //.......

        if (SaveAlert != null) await SaveAlert.ShowAsync("success", "OK");
    }
    catch (Exception ex)
    {
        if (SaveAlert != null) await SaveAlert.ShowAsync("danger", ex.Message);
    }
    finally
    {
        await SetIsLoading(false);
    }

    StateHasChanged();
}

}

警报组件从未更新,在“OnParametersSetAsync”中“Message”参数始终为空。

我尝试过非异步版本的方法,到处都放“StateHasChanged”,不调用“Hide”方法,还删除了[ParameterAttribute]属性,因此它被用作常规变量,但对我来说似乎没有什么用

我对 Blazor 还不太熟悉,所以不知道还有什么相关内容。我使用的应用程序为 RenderMode="Server"

我做错了什么?

blazor-server-side
  • 1 个回答
  • 30 Views
Martin Hope
David Thielen
Asked: 2024-09-18 10:30:30 +0800 CST

Blazor-如何强制将变量更新到底层组件

  • 5

我有一个组件,它会在切换到其他页面时弹出一个对话框,询问您是否确定要放弃更改。我将其放在每个页面上,如下所示:

<ConfirmNavigation HasUnsavedChanges="@HasUnsavedChanges" />

此组件包括:

[Parameter]
public bool HasUnsavedChanges { get; set; }

private async Task OnBeforeInternalNavigation(LocationChangingContext context)
{
    if (!HasUnsavedChanges)
        return;

我的问题是,在父页面中,处理提交点击,我有:

HasUnsavedChanges = false;
await Task.Delay(1);
Navigation.NavigateTo(gotoUrl);

这不起作用。该方法在执行完这两行代码后返回,并且ConfirmNavigation仍然认为HasUnsavedChanges是 true。

有没有办法让 的改变值变成HasUnsavedChanges?ConfirmNavigation我最好的选择是添加一个方法来ConfirmNavigation设置值吗?我不喜欢这样做,因为它绕开了 ,这HasUnsavedChanges="@HasUnsavedChanges"违反了组件应该如何交互。

blazor-server-side
  • 1 个回答
  • 28 Views
Martin Hope
RJM
Asked: 2024-05-29 16:54:05 +0800 CST

如何在自定义组件中显示 Blazorise 验证?

  • 6

我将 Blazorise 与服务器端 Blazor 应用程序一起使用。当我尝试将 Blazorise 输入组件包装在自定义组件中时,验证消息停止工作。

我的意思是,当我单击“提交”时,我在具有无效值的字段下没有看到任何错误消息。如果我不包装 Blazorise 输入并单击“提交”,我会看到错误消息。

这是一个例子。该表单包含相同字段两次。一个包裹在我的自定义组件内TextField,另一个打开。

    <Form>
        <Validations @ref="@fluentValidations" Mode="ValidationMode.Manual" Model="AccountDto" HandlerType="typeof(FluentValidationHandler)">
            <TextField Label="Name" @bind-Text="@Account.Name" />
            <Validation>
                <Field>
                    <FieldLabel For="account-name-input">Name</FieldLabel>
                    <TextEdit ElementId="account-name-input" @bind-Text="@Account.Name">
                        <Feedback>
                            <ValidationError />
                        </Feedback>
                    </TextEdit>
                </Field>
            </Validation>
        </Validations>
        <Field>
            <Button Type="ButtonType.Submit"
                PreventDefaultOnSubmit
                Clicked="Submit">
                Submit
            </Button>
        </Field>
    </Form>

后面的代码包含以下表单内容(我遗漏了很多废话):

    private Validations fluentValidations = null!;

    private async Task Submit()
    {
        if (await fluentValidations.ValidateAll())
            await CreateAccount(Account);
    }

自定义组件看起来像。(文件背后的代码不包含任何有趣的内容):

    <Validation>
        <Field>
            <FieldLabel For="@GetInputId()">
                @Label
            </FieldLabel>
            <TextEdit ElementId="@GetInputId()"
                      Text="@Text"
                      TextChanged="TextChanged"
                      Disabled="@Disabled">
                <Feedback>
                    <ValidationError />
                </Feedback>
            </TextEdit>
        </Field>
    </Validation>

我知道验证工作正常,因为错误确实出现在展开的组件中,但不会出现在我的组件中。

blazor-server-side
  • 1 个回答
  • 29 Views
Martin Hope
flip
Asked: 2024-04-04 20:26:09 +0800 CST

EventCallback 抛出“当前线程未与调度程序关联”

  • 5

我正在尝试创建一个简单的搜索输入控件,具有基于计时器的去抖功能。

Search.razor:

<input type="search" placeholder="Search" @oninput=@((e) => SearchChanged(e)) />

@code {
    
  [Parameter]
  public EventCallback<string> OnSearchChanged { get; set; }

  private System.Timers.Timer? _debounceTimer;

  string Text = string.Empty;

  public void SearchChanged(ChangeEventArgs e)
  {
     Text = e.Value == null ? string.Empty : e.Value.ToString()!;
     // Debounce search
     _debounceTimer?.Stop();
     _debounceTimer?.Dispose();
     _debounceTimer = new System.Timers.Timer(200);
     _debounceTimer.Elapsed += DebounceTimerElapsed;
     _debounceTimer.Enabled = true;
     _debounceTimer.Start();
  }

  private void DebounceTimerElapsed(object? sender, EventArgs e)
  {
    _debounceTimer?.Dispose();
    OnSearchChanged.InvokeAsync(Text);    // <<< Dispatcher exception
  }
}

我认为在这个组件中包含去抖动功能是有意义的,这样我就不必在每个父级上重复它。但我似乎无法使用 EventCallback 让父组件知道计时器已过。它抛出了臭名昭著的The current thread is not associated with the Dispatcher异常。

Blazor University 上的此页面解释了非 UI 事件(例如Timer.Elapsed在另一个线程上生成)。计时器确实是罪魁祸首,因为显然如果我OnSearchChanged.InvokeAsync()直接从SearchChanged. 但InvokeAsync()在这种情况下似乎没有同步回 UI 线程。但我认为应该有一种简单的方法来完成这项工作。

有没有一种(简单)方法让父组件知道子组件中的计时器已过?

blazor-server-side
  • 1 个回答
  • 15 Views
Martin Hope
Eric
Asked: 2023-08-30 20:13:42 +0800 CST

MudCheckbox 事件调用

  • 5

目前我有这个:

 @foreach (var rol in Rollenlist)
 {
    <InputCheckbox class="form-check" @[email protected] @onclick="(() => RolSelected(rol.Id.Value))" />
 }

和

void RolSelected(int id) 
{
  ...
}

我想使用 MudCheckbox:

<MudCheckBox @bind-Checked="@rol.IsSelected" Label="@rol.Name" LabelPosition="LabelPosition.Start" Color="Color.Primary"
                               Size="MudBlazor.Size.Large" CheckedChanged="RolSelected(rol.Id.Value)"></MudCheckBox>

但它不起作用。

RZ1OO1O: The component parameter 'CheckedChanged' is used two or more times for this component. Parameters must be unique (case-insensitive). The component parameter 'CheckedChanged' is
generated by the '@bind-Checked' directive attribute.

CS1503: Argument 2: cannot convert from 'void' to 'Microsoft.AspNetCore.Components.EventCallback

在此输入图像描述

我怎样才能解决这个问题?

blazor-server-side
  • 1 个回答
  • 18 Views

Sidebar

Stats

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

    重新格式化数字,在固定位置插入分隔符

    • 6 个回答
  • Marko Smith

    为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会?

    • 2 个回答
  • Marko Smith

    VScode 自动卸载扩展的问题(Material 主题)

    • 2 个回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Martin Hope
    Fantastic Mr Fox msvc std::vector 实现中仅不接受可复制类型 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant 使用 chrono 查找下一个工作日 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor 构造函数的成员初始化程序可以包含另一个成员的初始化吗? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský 为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul C++20 是否进行了更改,允许从已知绑定数组“type(&)[N]”转换为未知绑定数组“type(&)[]”? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann 为什么 {2,3,10} 和 {x,3,10} (x=2) 的顺序不同? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +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