当前位置: 首页 > 面试题库 >

在JavaScript中使用Razor

谭昕
2023-03-14
问题内容

是否可以解决在视图(cshtml)中的JavaScript中使用Razor语法的问题?

我正在尝试将标记添加到Google地图中…例如,我尝试了此操作,但是却遇到了大量编译错误:

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

问题答案:

使用<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的语法的信息,<text>如果您只需要添加一两行JavaScript代码,它就比标签稍微麻烦一些。以下方法可能更可取,因为它可以减小生成的HTML的大小。(您甚至可以将addMarker函数移动到静态的缓存JavaScript文件中,以进一步减小大小):

<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更加正确。

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

更新2

值得注意的是,View代码确实不是放置JavaScript代码的好地方。JavaScript代码应该放在一个静态.js文件中,然后应该通过Ajax调用或通过扫描data-HTML中的属性来获取所需的数据。除了可以缓存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);
});


 类似资料:
  • 在 Rails 中使用 JavaScript 本文介绍 Rails 内建对 Ajax 和 JavaScript 等的支持,使用这些功能可以轻易的开发强大的 Ajax 程序。 读完本文,你将学到: Ajax 基本知识; 非侵入式 JavaScript; 如何使用 Rails 内建的帮助方法; 如何在服务器端处理 Ajax; Turbolinks 简介; 1 Ajax 简介 在理解 Ajax 之前,要

  • 问题内容: 我正在尝试从Webview中的javascript界面​​开始一项活动。该示例显示了一个烤面包。我怎么能称呼课程而不是敬酒? 这是html页面。 问题答案: 您必须先在Webview上注册JavaScriptInterface。JavaScriptInterFace可以是一个内部类,如下所示。此类将具有您可以从html页面(通过javaScript)调用的函数,并且可以在该函数内部编写

  • 本文向大家介绍在JavaScript中使用Document.title()吗?,包括了在JavaScript中使用Document.title()吗?的使用技巧和注意事项,需要的朋友参考一下 在title属性设置或返回的值title属性的元素,无非是提供关于元素的额外信息。这主要用作工具提示,在鼠标悬停时显示文本。Javascript提供了document.title()来获取标题。 语法 示例

  • 如何在javascript中使用webkit playsinline而不是在html5视频标记中使用?我想像在javascript中使用视频标记控制/自动播放属性一样使用它,或者如果你们有任何其他有效的方法?我正在开发一款PhoneGap iOS应用程序,可以流式播放视频。 以下是我尝试过的一些方法,但都不管用: 视频播放器。WebKitPlaysInline="webkit-playsinlin

  • 问题内容: 我有一些绝对必须使用实现的代码。例如,我要编写这样的程序: 有没有办法用Javascript做到这一点? 问题答案: 绝对!有一个名为Summer of Goto的项目,它使您可以最大程度地使用JavaScript,并将彻底改变您编写代码的方式。 这个JavaScript预处理工具可让您创建标签,然后使用以下语法转到标签: 例如,问题中的示例可以编写如下: 请注意,您不仅限于无穷无尽的

  • 问题内容: 我正在尝试使用Haversine距离公式但是我无法使用它,请参见以下代码 错误是: 我知道这是因为它需要执行以下操作: 但是,当我将此放在函数下方时,它仍然返回相同的错误消息。如何使用助手方法?还是有其他方法可以对此进行编码?谢谢! 问题答案: 此代码有效: