在控制器的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());
}
}
}
答案 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)