如果model为null,如何处理null异常,如何在mvc中查看它?

时间:2017-04-07 11:47:25

标签: c# asp.net-mvc entity-framework linq asp.net-mvc-4

在控制器的MVC应用程序中,我使用Entity Framework和LINQ。我将10条记录存储在变量中,然后将它们绑定到模型中。但如果没有记录,我就会收到错误

  

指数超出范围。必须是非负数且小于   集合。

虽然我在视图中处理了null异常。我收到编译时错误

  

无法使用数组初始值设定项初始化隐式类型变量。

查看:

  function initMap() {
            var labels = '12345678910';
            var labelIndex = 0;

           @if (Model != null)
                   {
                       var   myLatLng = { lat:  @Model[0].latitude.ToString(), lng: @Model[0].longitude.ToString() };
                   }

           else
                   {
                          var myLatLng = { lat:0, lng:0};//Bharat Seva Ashram   
                   }

控制器:

List<AssetTrackerViewModel> model = new List<AssetTrackerViewModel>();
/// PIR 1 //RAD:DN
try
{
    WebRequest req = WebRequest.Create(@"https://url");
    req.Method = "GET";
    req.Headers["Authorization"] = "Basic " + "pwd==";
    HttpWebResponse resp = req.GetResponse() as HttpWebResponse;
    var encoding = resp.CharacterSet == "" ? Encoding.UTF8 : Encoding.GetEncoding(resp.CharacterSet);
    using (var stream = resp.GetResponseStream())
    {
        var reader = new StreamReader(stream, encoding);
        var responseString = reader.ReadToEnd();

      **//here "items" im getting null / empty** 
       var items = Pirs.Where(a => !a.dataFrame.EndsWith("AAAAAAAAAAA="))
                                         .GroupBy(a => a.dataFrame.Substring(a.dataFrame.Length - 12))
                                         .Select(g => g.First())
                                         .OrderByDescending(a => a.timestamp)
                                         .Take(10);

        foreach (var item in items)
        {
            byte[] data = Convert.FromBase64String(item.dataFrame.ToString());
        }
    }
}

2 个答案:

答案 0 :(得分:2)

问题是以下代码被识别为Razor代码,而您可能期望它是Javascript代码:

var   myLatLng = { lat:  @Model[0].latitude.ToString(), lng: @Model[0].longitude.ToString() };

只需在Razor要忽略的语句之前添加@:

@if (Model != null)
{
    @: var myLatLng = { lat:  @Model[0].latitude.ToString(), lng: @Model[0].longitude.ToString() };
}
else
{
    @: var myLatLng = { lat:0, lng:0 };
}

答案 1 :(得分:1)

只需检查列表是否为&gt; 0

@if (Model != null && Model.Count >0)