将参数传递给Url.Action

时间:2014-05-20 15:06:50

标签: javascript asp.net parameters google-api infowindow

这是我的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})\';" />' + '&nbsp;';
            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")\';" />' + '&nbsp;';

1 个答案:

答案 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 + '" />'
    + '&nbsp;';

您可能需要考虑某种形式的模板,以使这种HTML结构更具可读性。