我正在使用 MVC 包装器使用剑道图表,我需要根据模型中的数据在运行时添加系列。
我已经验证了我的模型在即将呈现图表时是否包含有效数据
视图的模型是一个图表小部件对象,其中包含一个系列列表
这只是图表系列的列表
预算图表小部件
namespace STC.Widgets.Budgeting
{
using System;
using System.Collections.Generic;
using Budget;
using Extensions;
using Helpers;
public class BudgetChartWidget
{
public BudgetChartWidget()
{
SeriesList = new List<IBudgetChartSeries>();
}
public List<IBudgetChartSeries> SeriesList { get; set; }
public string ChartTitle { get; set; }
}
}
**Budget Chart Series**
namespace STC.Widgets.Data.Budgeting
{
using System.Collections.Generic;
public class BudgetChartSeries : IBudgetChartSeries
{
public BudgetChartSeries(string seriesName)
{
Values = new List<IChartValue>();
SeriesName = seriesName;
}
public string SeriesName { get; set; }
public List<IChartValue> Values { get; set; }
}
}
然后,每个图表系列都包含值
爱克特价值
namespace STC.Widgets.Data.Budgeting
{
using System;
public interface IChartValue
{
string DisplayValue { get; set; }
DateTime Period { get; set; }
double? Value { get; set; }
}
}
图表的部分视图
@using STC.Widgets.Data.Budgeting
@model STC.Widgets.Budgeting.BudgetChartWidget
<div>
@(Html.Kendo().Chart(Model.SeriesList)
.Theme((string) ViewBag.ThemeName)
.Name("BudgetViewer" + 1)
.Series(series =>
{
foreach (var item in Model.SeriesList)
{
series.Column(item.Values).Field("Value").CategoryField("DisplayValue").Name(item.SeriesName);
}
})
.Legend(legend => legend.Position(ChartLegendPosition.Bottom).Visible(true))
.ValueAxis(axis => axis.Numeric()
.MajorGridLines(lines => lines.Visible(true))
.NarrowRange(true)
.Labels(labels => labels.Format("{0:N0}"))
.Line(line => line.Visible(true))
.Crosshair(crosshair => crosshair.Visible(true)
.Tooltip(t => t.Visible(true)))
)
.CategoryAxis(axis => axis
.Labels(labels => labels.Rotation(-90))
.MajorGridLines(lines => lines.Visible(false))
.Crosshair(crosshair => crosshair.Visible(true)
.Tooltip(t => t.Visible(true)))
)
.Tooltip(tooltip => tooltip.Visible(true).Format("{0:N0}").Shared(true)))
</div>
当我运行这个时,序列显示在底部图例中,但图表中没有数据显示
我已经检查过,没有Javascript错误
当我使用Internet Explorer查看图表的来源时,我可以看到数据在那里
我看不出我创建每个系列的方式有什么问题,我什至尝试了不同的传递参数的方式。
唯一与我的情况相关的是我正在使用的那个
任何人都可以看看我是否错过了一些非常明显的东西吗?
保罗
我刚刚遇到了类似的问题,就我而言,图表最初没有显示,但是当我单击图例时,图表按预期显示。检查后,图表最初似乎没有正确调整大小。
<div class="chart-wrapper">
@(Html.Kendo().Chart(...)
.....
</div>
$(document).ready(function () {kendo.resize($(".chart-wrapper"));});
似乎解决了这个问题。