Verwenden Sie das hier<text>
beschriebene Pseudoelement , um den Razor-Compiler wieder in den Inhaltsmodus zu versetzen:
<script type="text/javascript">
// Some JavaScript code here to display map, etc.
// Now add markers
@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>
Aktualisieren:
Scott Guthrie hat kürzlich über die @:
Syntax in Razor geschrieben, die etwas weniger klobig ist als das <text>
Tag, wenn Sie nur ein oder zwei Zeilen JavaScript-Code hinzufügen müssen. Der folgende Ansatz wäre wahrscheinlich vorzuziehen, da er die Größe des generierten HTML-Codes verringert. (Sie können die Funktion addMarker sogar in eine statische, zwischengespeicherte JavaScript-Datei verschieben, um die Größe weiter zu verringern.)
<script type="text/javascript">
// Some JavaScript code here to display map, etc.
...
// Declare addMarker function
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);
});
}
// Now add markers
@foreach (var item in Model) {
@:addMarker(@item.Latitude, @item.Longitude, '@item.Title', '@item.Description', map);
}
</script>
Der obige Code wurde aktualisiert, um den Aufruf addMarker
korrekter zu gestalten.
Zur Verdeutlichung @:
zwingt Razor den Textmodus zurück, obwohl der addMarker
Aufruf dem C # -Code sehr ähnlich sieht. Razor greift dann auf die @item.Property
Syntax zurück, um zu sagen, dass der Inhalt dieser Eigenschaften direkt ausgegeben werden soll.
Update 2
Es ist erwähnenswert, dass View-Code wirklich kein guter Ort ist, um JavaScript-Code einzufügen. JavaScript-Code sollte in eine statische .js
Datei eingefügt werden und dann die benötigten Daten entweder aus einem Ajax-Aufruf oder durch Scannen abrufendata-
Attributen aus dem HTML- . Dies ermöglicht nicht nur das Zwischenspeichern Ihres JavaScript-Codes, sondern vermeidet auch Probleme mit der Codierung, da Razor für die Codierung von HTML, nicht jedoch von JavaScript ausgelegt ist.
Code anzeigen
@foreach(var item in Model)
{
<div data-marker="@Json.Encode(item)"></div>
}
JavaScript-Code
$('[data-marker]').each(function() {
var markerData = $(this).data('marker');
addMarker(markerData.Latitude, markerData.Longitude,
markerData.Description, markerData.Title);
});
@:
Syntax.