c#MVC使用带有RouteValueDictionary的@ url.action中的复杂对象

时间:2017-02-03 14:44:08

标签: c# asp.net-mvc asp.net-mvc-4 url.action

我必须在C#MVC中创建一个统计项目,其中包含需要为用户提供不同渲染的几个步骤(浏览器,PDF文档,Excel,...) 对于浏览器部分,我目前有一个包含集合的复杂类,该集合用作显示表,图表或两者的视图的模型。

我使用@ url.action来获取图表的图像 我已经定义了一个RouteValueDictionary来传递url.action参数中的对象

  

src =“@ Url.Action(”SampleChart“,”Statistique“,Model.RouteValues))”

在控制器中:boolean和string被填充但不是字典(resultatsStatistique)。你有什么想法解决我的问题吗?

以下是模型的简化版本

    public class StatisticDTO
{
    public virtual string Stat_Title { get; set; }
    public bool DisplayChart { get; set; }
    public bool DisplayTable { get; set; }
    public Dictionary<string, RowStat> resultatsStatistique;
    public RouteValueDictionary RouteValues
    {
        get
        {
            var rvd = new RouteValueDictionary();
            rvd["DisplayChart"] = DisplayChart;
            rvd["DisplayTable"] = DisplayTable;
            rvd["resultatsStatistique"] = resultatsStatistique;
            return rvd;
        }
    }
}
public class RowStat
{
    public virtual string prest_libe { get; set; }
    public virtual decimal prest_effec { get; set; }
    public virtual int prest_order { get; set; }
    public virtual string prest_sex { get; set; }
} 

以下是我的观点的简化版

    @model StatisticDTO

<div>
    @if (Model.DisplayChart )
    {
        <div>
             <img  src="@Url.Action("SampleChart", "Statistique", Model.RouteValues ))" />
         </div>
   }


    @if (Model.DisplayTable)
    {
        @Html.Partial("_Tableau", Model)
    }

</div>

以下是控制器的简化版本

public ActionResult SampleChart(StatisticDTO modelIN)
               {
(.....)
MemoryStream ms = new MemoryStream();
            chart.SaveImage(ms, ChartImageFormat.Png);
            return File(ms.ToArray(), "image/png");
}

1 个答案:

答案 0 :(得分:0)

好。感谢您的意见。 可能没有简单的解决方案。 所以我寻找另一种解决方案来获取我的图像源。这里的主题不在此,但对于那些感兴趣的人来说,解决方案不是在两个动作之间进行往返。您必须在第一个操作中生成文件,并将其作为字节数组传递给模型

在第一个动作中就像这样

ms = new MemoryStream();
Chart.SaveImage(ms, ChartImageFormat.Png);
modelOUT.ByteArray = ms.ToArray();

并且在视图中

@{
    var base64 = Convert.ToBase64String(Model.ByteArray);
    var imgSrc = String.Format("data:image/gif;base64,{0}", base64);
}

<img src="@imgSrc" />

MVC How to display a byte array image from model