2012-10-16 31 views
0

我在特定视图中添加了MvcContrib网格。在网格中,连同列数据,我也有一个单选按钮列。我正在尝试获取选定的单选按钮单击事件,但未按预期发生。我不知道实施有什么问题。你们可以看看,并给出一些建议或代码片段来解决这个问题。在MVCContrib Grid中使用jquery选择Radiobutton MVC3

<%= Html.Grid(Model.Items) 
     .Columns(column => 
        { 
         column.For(x => x.Name) 
          .Named(Html.OrderBy(null, "DisplayRestaurantsList", "Group", ViewContext.RouteData.Values, "sortBy", "sortDir", true, Model.SortDirection, Model.SortBy, "restaurantname", "Restaurant")); 
         column.For(x => x.Contact.GetDisplayName()) 
          .Named(Html.OrderBy(null, "DisplayRestaurantsList", "Restaurant", ViewContext.RouteData.Values, "sortBy", "sortDir", true, Model.SortDirection, Model.SortBy, "administrator", "Administrator")); 
         column.For(x => Html.ActionLink("Remove", "RemoveRestaurant", "Group", new { id = x.ID, GroupID=x.Group.ID }, null)) 
          .DoNotEncode(); 
         column.For(x => Html.RadioButton("defaultRastaurant",x.ID,(!x.Group.ID.Value.ToString().IsEmptyOrNull() && x.ID==x.Group.DefaultRestaurantID) ? true:false)).Named("default").DoNotEncode(); 
        }) 
     .Attributes(@class => "table-1 gapmb40") 
     .Empty("There are no restaurants that match your criteria.") 
     .RowStart(row => string.Format("<tr{0}>", row.IsAlternate ? "style=\"background-color:#CCDDCC\"" : "")) 

    %> 

jQuery代码来选择单选按钮点击:

$("input[type='radio']").click(function() { 
       alert("kaustubh"); 
      }); 

也试过以下一个太:

$("input[name='defaultRastaurant']").change(function() { 
      alert("kaustubh");    
          }); 

回答

1

看起来像它的一个事件委派问题。当事件处理程序相关联的给它的元素不存在于DOM ..

尝试此

$("body").on("click"," input[type='radio']" ,function() { 
     alert("kaustubh"); 
}); 

主体可以由任何非静态父其中单选按钮存在替换..