c# - 在MVC中的javascript中嵌套foreach
问题描述
我正在创建一个 ASP.NET MVC 应用程序,在其中显示带有数据库坐标的谷歌地图。我是这方面的新手,我遇到了嵌套 foreach 循环的问题......在 C# Razor 页面上,我有一个 JavaScript 函数“Initialize”,我在其中循环遍历包含坐标的对象数组并创建折线基于它们,然后将其添加到地图中。这工作正常,代码如下所示:
var latLongCoordinates =
[
@foreach(var itemFlightState in Model.QARFlights[0].FlightStates)
{
<text> new google.maps.LatLng(@itemFlightState.PresentPosLatDec.ToString().Replace(",", "."),
@itemFlightState.PresentPosLongDec.ToString().Replace(",", ".")),</text>
}
];
var flightPath = new google.maps.Polyline({
path: latLongCoordinates,
geodesic: true,
strokeColor: '#FF0000',
strokeOpacity: 1.0,
strokeWeight: 2
});
flightPath.setMap(map);
但是,我需要显示几条不同的折线(每个航班一条),因此需要使用嵌套的 foreach 循环来实现这一点,但它不起作用。我想用另一个 foreach 循环围绕上面的示例来绘制所有航班,而不仅仅是上面示例中索引为 0 的航班。以下是我想做的事情:
@foreach (var itemQARFlight in Model.QARFlights) {
var latLongCoordinates =
[
@foreach(var itemFlightState in itemQARFlight.FlightStates)
{
<text> new google.maps.LatLng(@itemFlightState.PresentPosLatDec.ToString().Replace(",", "."),
@itemFlightState.PresentPosLongDec.ToString().Replace(",", ".")),</text>
}
];
var flightPath = new google.maps.Polyline({
path: latLongCoordinates,
geodesic: true,
strokeColor: '#FF0000',
strokeOpacity: 1.0,
strokeWeight: 2
});
flightPath.setMap(map);
}
当添加周围的@foreach 时,下面的所有内容都会变为红色,并且解析器似乎不再理解我的意思了。
抱歉,如果这是一个微不足道的问题,但我真的无法解决它。任何帮助将不胜感激!最好的问候乌尔丽卡
解决方案
请注意,这@foreach
会将您带回到 C#,因此您需要再次将 JavaScript 包装在<text>
.
@foreach (var itemQARFlight in Model.QARFlights) {
<text>
var latLongCoordinates =
...
flightPath.setMap(map);
</text>
}
推荐阅读
- refactoring - 如何重构多个参考别名?
- android-studio - Android Studio Show 在后台时间应用程序中
- authentication - 服务器上的 ASP.NET Core 应用程序身份验证问题
- python - Python和C TCP套接字之间的通信
- python - 从主文件运行脚本的更好方法
- python - 当要测试的函数依赖于全局变量时的单元测试
- css - 全局命名 CSS 问题
- java - Project Reactorflux conCat,flux mergeSequential,flux mergeOrdered有什么区别
- javascript - 如何打破javascript中的for循环?
- c++ - 在 C++ 中处理文件期间的文件写入问题