2011-03-17 59 views
1

我使用下面的代码来捕捉变化的文本在HTML输入:使用jQuery捕捉变化在Telerik的MVC ComboBoxFor

$(document).ready(function() { 
    $(':input', document.myForm).bind("change", function() { setConfirmUnload(true); }); 
}); 

这工作正常正常的文本框和复选框。

我正在使用Telerik的MVC ComboBoxFor呈现输入标记,但似乎没有触发上述JQuery。

任何想法如何捕捉?

这是HTML的呈现方式:

<div class="t-widget t-combobox t-header" id="InterviewRequired"> 
<div class="t-dropdown-wrap t-state-default"> 
    <input class="t-input" id="InterviewRequired-input" name="InterviewRequired-input" title="InterviewRequired" type="text" value="Select" /> 
    <span class="t-select t-header"> 
     <span class="t-icon t-arrow-down">select</span> 
    </span> 
</div> 
<input id="InterviewRequired-value" name="InterviewRequired" style="display:none" type="text" value="0" /> 

我也问过这个问题上Telerik forums的情况下,我没有在这里得到答案。

+0

? – Raja 2011-03-17 11:45:30

+0

不,我已经添加了HTML生成的问题 – ozz 2011-03-17 11:55:01

回答

2

观看演示here。该组合框被渲染为<input/>和弹出<div/>

<div class="t-dropdown-wrap t-state-default"> 
    <input type="text" value="Chai" name="ComboBox-input" id="ComboBox-input" class="t-input" autocomplete="off"> 
    <span class="t-select t-header"> 
    <span class="t-icon t-arrow-down">select</span> 
    </span> 
</div> 

着眼于客户端的文档,你最有可能将需要注册位于here一个客户端事件。

<%= Html.Telerik().ComboBox() 
      .Name("ComboBox") 
      .ClientEvents(events => events 
       .OnChange("onChange") 
      ) 
    %> 

    <script type="text/javascript"> 
     function onChange(e) { 
      setConfirmUnload(true); 
     } 
    </script> 

它也像你应该能够使用jQuery做到这一点仅仅从这个例子:

<%= Html.Telerik().ComboBox().Name("ComboBox") %> 

<script type="text/javascript"> 
    $(document).ready(function() { 
     $('#ComboBox').bind('change', function(e) { // your code }); 
    }); 
</script> 

也许尝试:

$(document).ready(function() { 
    $('#myComboBox').bind("change", function() { setConfirmUnload(true); }); 
}); 
+1

感谢马克,这工作的一种享受! – ozz 2011-03-17 12:04:22

5

继承人就可以把事件的列表到: http://www.telerik.com/community/forums/aspnet-mvc/combobox/jquery-event-names.aspx

如果您想要将更改事件附加到更动态的方式使用JavaScript,你会附加到“valueChange”事件而不是“变化”:我没有使用Telerik控制,但不应该ComboBoxFor渲染为选择而不是输入

$(document).ready(function() { 
    $('#ComboBoxId').bind("valueChange", function() { setConfirmUnload(true); }); 
}); 
+0

+1最后,有用的东西! – Samuel 2014-07-07 20:49:46