请使用伪元素<text>
,如此处所述,将Razor编译器强制返回到内容模式:
<script type="text/javascript">
@foreach (var item in Model) {
<text>
var markerlatLng = new google.maps.LatLng(@(Model.Latitude), @(Model.Longitude));
var title = '@(Model.Title)';
var description = '@(Model.Description)';
var contentString = '<h3>' + title + '</h3>' + '<p>' + description + '</p>'
var infowindow = new google.maps.InfoWindow({
content: contentString
});
var marker = new google.maps.Marker({
position: latLng,
title: title,
map: map,
draggable: false
});
google.maps.event.addListener(marker, 'click', function () {
infowindow.open(map, marker);
});
</text>
}
</script>
更新:
Scott Guthrie最近发表了一篇文章,介绍Razor中的@:
语法,如果你只需要添加一两行JavaScript代码,则此语法比<text>
标签更简洁。下面的方法可能更可取,因为它减少了生成的HTML大小(甚至可以将addMarker函数移动到静态缓存的JavaScript文件中以进一步减小文件大小):
<script type="text/javascript">
...
function addMarker(latitude, longitude, title, description, map)
{
var latLng = new google.maps.LatLng(latitude, longitude);
var contentString = '<h3>' + title + '</h3>' + '<p>' + description + '</p>';
var infowindow = new google.maps.InfoWindow({
content: contentString
});
var marker = new google.maps.Marker({
position: latLng,
title: title,
map: map,
draggable: false
});
google.maps.event.addListener(marker, 'click', function () {
infowindow.open(map, marker);
});
}
@foreach (var item in Model) {
@:addMarker(@item.Latitude, @item.Longitude, '@item.Title', '@item.Description', map);
}
</script>
已更新上面的代码,使调用addMarker
更加正确。
需要说明的是,@:
强制Razor返回到文本模式,即使addMarker
调用看起来很像C#代码。然后,Razor使用@item.Property
语法来直接输出这些属性的内容。
更新2
值得注意的是,视图代码并不是放置JavaScript代码的好地方。JavaScript代码应该放在静态的.js
文件中,然后它应该通过Ajax调用或通过扫描HTML中的data-
属性来获取所需的数据。除了使JavaScript代码可以缓存外,这还避免了编码问题,因为Razor被设计用于对HTML进行编码,但不是针对JavaScript。
视图代码
@foreach(var item in Model)
{
<div data-marker="@Json.Encode(item)"></div>
}
JavaScript 代码
$('[data-marker]').each(function() {
var markerData = $(this).data('marker');
addMarker(markerData.Latitude, markerData.Longitude,
markerData.Description, markerData.Title);
});
@:
语法,我有更新,你可能会感兴趣。 - StriplingWarrior