这是我的javascript函数:
function addMarker(x, y, meas_type, meas_status, meas_key) {
var location = new google.maps.LatLng(x, y);
var contentString = '<h3 >' + meas_type + '</h3>' + '<p>Status: ' + '<span style="color: red">' + meas_status + '</span>' + '</p>' + '<input type="button" class="btn btn-default" value="Details" onclick="window.location.href=\'@Url.Action("Index", "Home", new { param = meas_key})\';" />' + ' ';
var marker = new google.maps.Marker({
position: location,
map: map,
});
var infowindow = new google.maps.InfoWindow({
content: contentString
});
google.maps.event.addListener(marker, 'click', function () {
infowindow.open(map, marker);
});
}
现在在contentString变量中,我想传递给index方法meas_key作为参数!我该怎么做?它没有这样工作。
这个工作正常,但我需要发送meas_key作为参数:
var contentString = '<h3 >' + meas_type + '</h3>' + '<p>Status: ' + '<span style="color: red">' + meas_status + '</span>' + '</p>' + '<input type="button" class="btn btn-default" value="Details" onclick="window.location.href=\'@Url.Action("Index", "Home")\';" />' + ' ';
答案 0 :(得分:0)
这里的问题是@Url.Action
是在服务器端完成的,当然没有办法在那里传递一个javascript变量。所以你可能需要这样做:
var url = '@Url.Action("Index", "Home")' + '?param=' + meas_type;
var contentString =
'<h3 >' + meas_type + '</h3>'
+ '<p>Status: ' + '<span style="color: red">' + meas_status + '</span>' + '</p>'
+ '<input type="button" class="btn btn-default" value="Details" onclick="window.location.href=' + url + '" />'
+ ' ';
您可能需要考虑某种形式的模板,以使这种HTML结构更具可读性。