0

我使用 Telerik-MVC,并且在更改组合框的值时尝试重新绑定网格。一切似乎都正常,除了我无法获得组合框的选定值。这是我的代码:

网格 :

@{Html.Telerik().Grid(Model)
        .Name("Grid")
        .Columns(columns =>
        {
            columns.Bound(o => o.Col1);
            columns.Bound(o => o.Col2);
            columns.Bound(o => o.Col3);
        })
        .DataBinding(dataBinding => dataBinding.Ajax()
             .Select("_MyAction", "MyController")
        )
        .ClientEvents(events => events.OnDataBinding("Grid_onDataBinding"))
}

组合框 :

@(Html.Telerik().ComboBox()
        .Name("ComboBox")
        .HtmlAttributes(new { id = "ComboBoxCode" })
        .BindTo(new SelectList(Model.GroupBy(x => x.Code)
                              .Select(o => o.First()).ToList(), 
                              "Code", "Code"))
        .ClientEvents(events => events
                .OnChange("onComboBoxChange")
        )
)

脚本 :

function onComboBoxChange(e) {
    $("#Grid").data("tGrid").rebind();
}
function Grid_onDataBinding(e) {
    var code = /* I need to get the combobox value here */;
    e.data = { myCode: code };
}

控制器 :

    [GridAction]
    public ActionResult _MyAction(string myCode)
    {
        Console.WriteLine("Code : " + code);
        /*
            Set new model here
        */
        return View(new GridModel(newModel));
    }

我试过这样的事情:

var e = document.getElementById("ComboBoxCode");
var code = e.options[e.selectedIndex].text;

但它不起作用。你能告诉我如何解决这个问题并获得正确的价值吗?

4

1 回答 1

1

问题是当您重新绑定网格时,您并没有真正使用 ComboBox 选择的值。您的onComboBoxChange函数告诉网格重新绑定,它通过转到_MyAction方法来完成。您在任何时候都没有传入 ComboBox 值。您应该做的是在数据绑定之前,获取选定的值并将其传递给您的控制器操作。有关详细信息,请参阅http://www.telerik.com/help/aspnet-mvc/telerik-ui-components-grid-client-api-and-events.html#OnDataBinding。像这样的东西:

function Grid_onDataBinding(e) {
    var combobox = $('#ComboBox').data('tComboBox');
    e.data = { code: combobox.value };
}

(请注意,我实际上没有对 ComboBox 做过任何工作,因此没有对此进行测试,但这至少应该让您走上正确的道路。请参阅ComboBox 文档。)

于 2013-09-16T22:35:29.847 回答