在 JavaScript 中使用 Razor

2022-08-29 23:14:09

是否有可能,或者是否有解决方法在视图()中的JavaScript中使用Razor语法?cshtml

我正在尝试向谷歌地图添加标记...例如,我尝试了这个,但我收到了大量的编译错误:

<script type="text/javascript">

    // Some JavaScript code here to display map, etc.

    // Now add markers
    @foreach (var item in Model) {

        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);
        });
    }
</script>

答案 1

使用伪元素(如此处所述)强制 Razor 编译器返回到内容模式:<text>

<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>

更新:

Scott Guthrie最近发布了关于Razor中的语法的文章,如果你只需要添加一两行JavaScript代码,它比标签稍微不那么笨拙。以下方法可能更可取,因为它减小了生成的 HTML 的大小。(您甚至可以将 addMarker 函数移动到静态的缓存 JavaScript 文件中,以进一步减小大小):@:<text>

<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>

更新了上面的代码,使对 addMarker 的调用更加正确。

为了澄清,强制Razor回到文本模式,即使调用看起来很像C#代码。然后,Razor 选取语法,说它应该直接输出这些属性的内容。@:addMarker@item.Property

更新 2

值得注意的是,View代码确实不是放置JavaScript代码的好地方。JavaScript代码应该放在一个静态文件中,然后它应该从Ajax调用或通过扫描HTML中的属性来获取它需要的数据。除了可以缓存JavaScript代码之外,这还可以避免编码问题,因为Razor旨在为HTML编码,而不是JavaScript。.jsdata-

查看代码

@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);
});

答案 2

我刚刚编写了这个帮助程序函数。把它放进去 :App_Code/JS.cshtml

@using System.Web.Script.Serialization
@helper Encode(object obj)
{
    @(new HtmlString(new JavaScriptSerializer().Serialize(obj)));
}

然后在您的示例中,您可以执行如下操作:

var title = @JS.Encode(Model.Title);

请注意,我没有在它周围加上引号。如果标题已包含引号,则不会爆炸。似乎也可以很好地处理字典和匿名对象!