javascript - Blazor TypeError : Cannot read property 'removeChild' of null at Object. e [作为 removeLogicalChild]

标签 javascript c# asp.net-core blazor blazor-server-side

我为双列表框创建了一个组件。一切都很好,但是当我提交时出现错误。

 <EditForm Model="Model.Report" class="kt-form" OnValidSubmit="Model.OnSearch">
                <div class="modal-header">
                    <h5 class="modal-title" id="exampleModalLabel">Edit Columns</h5>
                    <button type="button" class="close" data-dismiss="modal" aria-label="Close">
                    </button>
                </div>
                <div class="modal-body">
                    <div class="row">
                        <div class="col-md-12">
                            <Project.Components.DualListbox ReportColumns="Model.Report.ReportColumns" Id="ReportColumns" @bind-Value="@Model.Report.ReportColumns"></Project.Components.DualListbox>
                        </div>
                    </div>
                </div>
                <div class="modal-footer">
                    <button type="button" class="btn btn-secondary btn-sm" @onclick="Model.OnCloseModal"><i class="la la-close"></i> Close</button>
                    <button type="submit" class="btn btn-primary btn-sm"><i class="la la-exchange"></i> Change</button>
                </div>
            </EditForm>
DualListbox Razor 代码:
@typeparam TValue
@inherits InputBase<TValue>


@if (ReportColumns != null)
{
    <select id="@Id" class="kt-dual-listbox" multiple>

        @foreach (var column in ReportColumns.OrderBy(c => c.Sort))
        {
            if (column.IsChecked == 1)
            {
                <option value="@column.Id" selected>@column.Title</option>
            }
            else
            {
                <option value="@column.Id">@column.Title</option>
            }
        }
    </select>
}
* DualListbox代码隐藏 *:
using Project.Models;
using Microsoft.AspNetCore.Components;
using Microsoft.AspNetCore.Components.Forms;
using Microsoft.JSInterop;
using System;
using System.Collections.Generic;
using System.Globalization;
using System.Linq;
using System.Threading.Tasks;

namespace Project.Components
{
    public partial class DualListbox<TValue> : InputBase<TValue>
    {
        [Parameter] public string Id { get; set; }
        [Inject] IJSRuntime JSRuntime { get; set; }
        [Parameter] public ICollection<ReportColumn> ReportColumns { get; set; }

        public DotNetObjectReference<DualListbox<TValue>> DotNetRef;
        [Parameter] public EventCallback<object> OnChanged { get; set; }
        protected override bool TryParseValueFromString(string value, out TValue result, out string validationErrorMessage)
        {
            try
            {
                if (value == "null")
                {
                    value = null;
                }
                if (typeof(TValue) == typeof(string))
                {
                    result = (TValue)(object)value;
                    validationErrorMessage = null;

                    return true;
                }
                else if (typeof(TValue) == typeof(int) || typeof(TValue) == typeof(int?))
                {
                    int.TryParse(value, NumberStyles.Integer, CultureInfo.InvariantCulture, out var parsedValue);
                    result = (TValue)(object)parsedValue;
                    validationErrorMessage = null;

                    return true;
                }

                throw new InvalidOperationException($"{GetType()} does not support the type '{typeof(TValue)}'.");
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }

        protected override void OnInitialized()
        {
            base.OnInitialized();
            DotNetRef = DotNetObjectReference.Create(this);
        }

        protected override async Task OnAfterRenderAsync(bool firstRender)
        {
            await base.OnAfterRenderAsync(firstRender);
            if (firstRender)
            {
                await JSRuntime.InvokeVoidAsync("dualListboxComponent.init", Id, DotNetRef, "Change_SelectWithFilterBase");
            }
        }

        [JSInvokable("Change_SelectWithFilterBase")]
        public void Change(string value)
        {
            try
            {
                if (value == "null")
                {
                    value = null;
                }

                var array = value.Split("#");
                if (array[0] == "add")
                {
                    int _value = int.Parse(array[1]);
                    var report = ReportColumns.Where(c => c.Id == _value).FirstOrDefault();
                    report.IsChecked = 1;
                }
                else
                {
                    int _value = int.Parse(array[1]);
                    var report = ReportColumns.Where(c => c.Id == _value).FirstOrDefault();
                    report.IsChecked = 0;
                } 

            }
            catch (Exception ex)
            {
                throw ex;
            }

            if (OnChanged.HasDelegate)
                OnChanged.InvokeAsync(value);
        }
    }
}

[2020-02-12T07:42:28.867Z] Error: There was an error applying batch 7. e.log @ blazor.server.js:15 blazor.server.js:8 Uncaught (in promise)


TypeError: Cannot read property 'insertBefore' of null at Object.s [as insertLogicalChild] (blazor.server.js:8) at e.insertText (blazor.server.js:8) at e.insertFrame (blazor.server.js:8) at e.applyEdits (blazor.server.js:8) at e.updateComponent (blazor.server.js:8) at Object.t.renderBatch (blazor.server.js:1) at e. (blazor.server.js:15) at blazor.server.js:15 at Object.next (blazor.server.js:15) at blazor.server.js:15 blazor.server.js:15 [2020-02-12T07:42:28.926Z] Error: System.AggregateException: One or more errors occurred. (TypeError: Cannot read property 'insertBefore' of null) ---> System.InvalidOperationException: TypeError: Cannot read property 'insertBefore' of null at Microsoft.AspNetCore.Components.RenderTree.Renderer.InvokeRenderCompletedCallsAfterUpdateDisplayTask(Task updateDisplayTask, Int32[] updatedComponents) --- End of inner exception stack trace ---

最佳答案

我的问题也在 FontAwesome 中。就我而言,将图标放入 <span></span>解决了问题。

   @if (conditional)
            {
                <span>
                    <i class="fas fa-check"></i>
                </span>
            }
            else
            {
                <span>
                    <i class="fas fa-times"></i>
                </span>
            }

关于javascript - Blazor TypeError : Cannot read property 'removeChild' of null at Object. e [作为 removeLogicalChild],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60183421/

相关文章:

c# - 通用存储库的依赖注入(inject)

.net - 仅使用 .NET Core 2.0 运行时的 Linux 上缺少运行时存储错误

Javascript 如何在 JSP 上使用带有两个提交按钮的确认对话框 onSubmit

native N 上的 Javascript 选择 :N relationship entity crm 2011

javascript - 让 Angular 检测 $scope 中的变化

c# - Entity Framework 中的 SaveChanges 与 SaveChangesAsync

c# - 有什么方法可以缩短具有大量字段的查询吗?

javascript - chrome.tabs.create 在 Chrome 启动时不起作用

c# - 具有多个 View 和一个演示者的 Winforms MVP

c# - 如何配置 Controller 返回 null 而不是 Guid.Empty?