在blazor中从js调用.net方法时,服务始终为null

时间:2020-06-16 11:15:51

标签: blazor blazor-client-side

我已经与this进行了核对,但仍然为空。

我有一个剃须刀组件,使用了datepickerrange。您可以在下面看到。我已经调用daterangepickerInit来初始化OnInitializedAsync()中的daterangepicker。在这里,我正在传递名为DotNetObjectReference的其他组件的BookedHoursWidgetComponent来访问那里的服务。

protected override async Task OnAfterRenderAsync(bool firstRender)
    {
        if (firstRender)
        {
            await Task.Delay(1).ContinueWith(async t =>
            {
                await JSRuntime.InvokeVoidAsync("DateRangePicker.daterangepickerInit");
            });
        }
    }

下面是DateRangePicker.daterangepickerInit的代码。

window.DateRangePicker = {
daterangepickerInit: function (dotNet) {

    if ($('#kt_dashboard_daterangepicker').length == 0) {
        return;
    }

    var picker = $('#kt_dashboard_daterangepicker');
    var start = moment().startOf('month');
    var end = moment().endOf('month');

    function cb(start, end, label) {

        var title = '';
        var range = '';

        if ((end - start) < 100 || label == 'Today') {
            title = 'Today:';
            range = start.format('MMM D');
        } else if (label == 'Yesterday') {
            title = 'Yesterday:';
            range = start.format('MMM D');
        } else {
            range = start.format('MMM D') + ' - ' + end.format('MMM D');
        }

        picker.find('#kt_dashboard_daterangepicker_date').html(range);
        picker.find('#kt_dashboard_daterangepicker_title').html(title);

        Date.prototype.yyyymmdd = function () {
            var mm = this.getMonth() + 1;
            var dd = this.getDate();

            return [this.getFullYear(),
            (mm > 9 ? '' : '0') + mm,
            (dd > 9 ? '' : '0') + dd
            ].join('');
        };

        var graphFilterModel = { StartDate: start.toDate().yyyymmdd(), EndDate: end.toDate().yyyymmdd() };

       // stateManager.save('GraphFilterModel', JSON.stringify(graphFilterModel));

        // window.localStorage['GraphFilterModel'] = JSON.stringify(GraphFilterModel);
        dotNet.invokeMethodAsync('ApplyFilter', graphFilterModel);
        // DotNet.invokeMethodAsync('Momo.Client', 'ApplyFilter', start.toDate().yyyymmdd(), end.toDate().yyyymmdd());
    }

    picker.daterangepicker({
        direction: KTUtil.isRTL(),
        startDate: start,
        endDate: end,
        opens: 'left',
        applyClass: "btn btn-sm btn-primary",
        cancelClass: "btn btn-sm btn-secondary",
        ranges: {
            'This Week': [moment().startOf('week'), moment()],
            'Last Week': [moment().subtract(1, 'week').startOf('week'), moment().subtract(1, 'week').endOf('week')],
            'This Month': [moment().startOf('month'), moment().endOf('month')],
            'Last Month': [moment().subtract(1, 'month').startOf('month'), moment().subtract(1, 'month').endOf('month')]
        }
    }, function (start, end, label) {
        cb(start, end, label);
    });

    cb(start, end, '');
}

}

下面的

BookedHoursWidgetComponent的代码。因此,这里是一种称为ApplyFilter的方法,当我选择日期范围时会从js中调用该方法。通过这种方法,我正在调用加载时间表的方法,但是问题是我总是将TimesheetServiceChartService设为null。

下面是我的BookedHoursWidgetComponent代码。

public class BookedHoursWidgetComponent : ComponentBase
{
    [Inject] TimesheetService TimesheetService { get; set; }

    [Inject] ProjectService ProjectService { get; set; }

    [Inject] ChartService ChartService { get; set; }

    [Inject] IMapper Mapper { get; set; }

    [Inject] protected IJSRuntime JSRuntime { get; set; } = null;

    [Inject] IStringLocalizer<Common> Localizer { get; set; }

    protected string BookingHours = string.Empty;

    protected override async Task OnInitializedAsync()
    {
        await ProjectService.GetAllProjects();
        await LoadTimesheet(new GraphFilterModel());
    }

    private async Task LoadTimesheet(GraphFilterModel graphFilterModel)
    {
        var timesheets = await TimesheetService.GetCurrentUserTimesheetsAsync();

        //var filterJson = await JSRuntime.InvokeAsync<string>("stateManager.load", nameof(GraphFilterModel));
        //var graphFilterModel = JsonSerializer.Deserialize<GraphFilterModel>(filterJson);

        var pattern = LocalDatePattern.CreateWithInvariantCulture("yyyyMMdd");
        LocalDate startDate, endDate;
        if (!string.IsNullOrEmpty(graphFilterModel.StartDate) && !string.IsNullOrEmpty(graphFilterModel.EndDate))
        {
            startDate = pattern.Parse(graphFilterModel.StartDate).GetValueOrThrow();
            endDate = pattern.Parse(graphFilterModel.EndDate).GetValueOrThrow();
            timesheets = timesheets.Where(x => x.Date >= startDate && x.Date <= endDate).ToList();
        }

        var bookedHoursTimesheets = Mapper.Map<List<BookedHoursTimesheet>>(timesheets);
        var BookedDuration = new Duration();
        foreach (var timesheet in bookedHoursTimesheets)
        {
            BookedDuration = BookedDuration.Plus(timesheet.Duration);
        }
        BookingHours = BookedDuration.ToString("HH:mm", null);

        // Chart code
        var BookedHoursGraphModelProjectWise = bookedHoursTimesheets.GroupBy(x => x.Project.Name).Select(y => new BookedHoursGraphModel
        {
            Project = y.Key,
            Hours = GetTotalDuration(y)
        }).OrderByDescending(x => x.Hours);

        var ProjectModel = BookedHoursGraphModelProjectWise.Take(9).ToList();
        var Other = BookedHoursGraphModelProjectWise.Where(x => !ProjectModel.Select(y => y.Project).Contains(x.Project));

        ProjectModel.Add(new BookedHoursGraphModel
        {
            Project = Localizer["BookedHoursWidget.Other"],
            Hours = Other.Sum(x => x.Hours)
        });

        string[] BackgroundColors = { Colors.Base.Shape[1], Colors.Base.Shape[2], Colors.State.States["brand"] };

        var GraphDataModel = new GraphDataModel
        {
            Data = ProjectModel.Select(x => x.Hours),
            Labels = ProjectModel.Select(x => x.Project),
            BackgroundColors = BackgroundColors
        };

        var BookedHoursGraphModel = ChartService.GenerateGraphModel(GraphDataModel);

        await JSRuntime.InvokeAsync<string>("CanvasGraph.LoadGraph",
                BookedHoursGraphModel, Settings.WidgetCanvas.BookedHoursWidgetCanvas);
    }

    protected double GetTotalDuration(IGrouping<string, BookedHoursTimesheet> model)
    {
        var Hour = new Duration();
        foreach (var objHours in model.Select(x => x.Duration))
        {
            Hour = Hour.Plus(objHours);
        }
        return Hour.TotalHours;
    }

    [JSInvokable]
    public async Task ApplyFilter(GraphFilterModel graphFilterModel)
    {
        //var pattern = LocalDatePattern.CreateWithInvariantCulture("yyyyMMdd");
        //var startDate = pattern.Parse(start).GetValueOrThrow();
        //var endDate = pattern.Parse(end).GetValueOrThrow();\
        await LoadTimesheet(graphFilterModel);
        // return Task.CompletedTask;
    }
}

为什么我将其设为null?我也使用了DotNetObjectReference.Create。我应该怎么做才能不获得服务null。

感谢帮助!。

0 个答案:

没有答案