1. ホーム
  2. ジャバスクリプト

[解決済み】RazorをJavaScriptで使用する場合

2022-03-24 09:08:52

質問

Razor の構文をビューの JavaScript で使用することは可能ですか? cshtml )?

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> 擬似要素について説明します。 ここで で、Razor コンパイラを強制的にコンテントモードに戻すことができます。

<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のコードが1行か2行の場合です。生成される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 をより正しく表示します。

明確にするために @: は Razor を強制的にテキストモードに戻しますが、たとえ addMarker の呼び出しは、C#のコードによく似ています。Razor は次に @item.Property の構文で、これらのプロパティの内容を直接出力するように言っています。

アップデート2

ビューコードは、JavaScriptのコードを置くのに適した場所ではないことに留意する必要があります。JavaScript のコードは、静的な .js ファイルから必要なデータを取得し、Ajax 呼び出しまたは data- 属性を使用します。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);
});