2

ASP.NET MVCアーキテクチャを使用しています。ボタンをクリックするとtelerikウィンドウが表示されますが、これは正常に機能します。コードは次のとおりです。

    <% Html.Telerik().Window()
           .Name("Search")
           .Visible(false)
           .Title("Select Users")
           .Content(() => {%>                                           
    <% using (Html.BeginForm("GetUsers", "Administration", FormMethod.Post, 
        new{id ="users-form"}))
    {%>

    <p class="note">Mention the Users name to display information</p>                                                 
    <label for="username">Name:</label>                                                        
    <%= Html.TextBox("username") %>                           
    <div class="form-actions">
    <button type="button" class="bUsername">Search</button>
    </div>  
    <% } %>                                           
    <%})
    .Width(400)                                            
    .Modal(true)                                            
    .Render();%>

しかし、telerikウィンドウのコンテンツ内にtelerikグリッドを追加しようとすると、エラーが発生します。コードは次のとおりです。

    <%= Html.Telerik().Grid(Model)
    .Name("Grid")
    .Columns(columns =>
    {
        columns.Bound(o => o.OrderID).Width(100);
        columns.Bound(o => o.ContactName).Width(200);
        columns.Bound(o => o.ShipAddress);
        columns.Bound(o => o.OrderDate).Format("{0:MM/dd/yyyy}").Width(120);
    })
    .DataBinding(dataBinding => 
    {
        dataBinding.Server().Select("FirstLook", "Grid", new { ajax =
            ViewData["ajax"] });
        dataBinding.Ajax().Select("_FirstLook",
            "Grid").Enabled((bool)ViewData["ajax"]);
    })
    .Scrollable(scrolling => scrolling.Enabled((bool)ViewData["scrolling"]))
    .Sortable(sorting => sorting.Enabled((bool)ViewData["sorting"]))
    .Pageable(paging => paging.Enabled((bool)ViewData["paging"]))
    .Filterable(filtering => filtering.Enabled((bool)ViewData["filtering"]))
    .Groupable(grouping => grouping.Enabled((bool)ViewData["grouping"]))
    .Footer((bool)ViewData["showFooter"])
     %>

エラー:.Content(()=> {%>----DelegateSystem.Funcは0個の引数を取りません。

それで、モーダルウィンドウ内にグリッドを配置できるかどうかを尋ねたいと思います。そうであれば、それを実装する方法と、それに代わるものが何であるかよりもできない場合はどうでしょうか。

4

2 に答える 2

2

ウィンドウにグリッドを表示するのに問題はないはずです。NorthwindデータベースのCustomerエンティティを使用する次のコードは、私にとっては問題なく機能しました。

        <% Html.Telerik().Window()
       .Name("TelerikWindow")
       .Title("Grid in Window")
       .Draggable(true)
       .Modal(true)
       .Content(() =>
       { %>
    <%= Html.Telerik().Grid(Model)
            .Name("TelerikGrid")
            .Columns(columns =>
            {
                columns.Bound(c => c.CustomerID);
                columns.Bound(c => c.CompanyName);
                columns.Bound(c => c.ContactName);
                columns.Bound(c => c.Address);
                columns.Bound(c => c.City);
            })
            .Pageable(pageSettings => pageSettings.Enabled(true).PageSize(10))
    %>
    <%})
       .Render();
    %>

コードを再確認して、ウィンドウのコンテンツが正しく設定されていることを確認します。これは、問題の原因であると思われるためです。

于 2012-01-28T16:03:30.260 に答える
1

デリゲートメソッドまたは直接出力を使用して、ウィンドウ内にグリッドを定義できます。

MVC 2:

<% Html.Telerik().Window()
    ...
    .Content(() =>
    {%>
        <%= Html.Telerik().Grid(***)
            ...
        %>
    <%})
    .Render();
%>

MVC 3かみそり:

@(Html.Telerik().Window()
    ...
    .Content(
        @<text>
            @(Html.Telerik().Grid<***>()
                ...
            )
        </text>
    )
)

関連項目:

ウィンドウ内のグリッド-フォーラム

RazorViewエンジンでの使用-ヘルプ

于 2012-01-28T20:17:07.220 に答える