onchange事件侦听器未在文本框上触发

时间:2012-11-26 17:12:48

标签: javascript jquery ajax onchange

我的表单有一个下拉列表,其中包含执行AJAX回发的国家/地区,并向城市提供另一个下拉列表。

我有文本框字段语音,它已经分配了一个事件监听器,出于调试目的,它只是向屏幕抛出一个警告信息框。

情景1

加载表单时,将使用登录的用户所在国家/地区预先选择国家/地区下拉列表,并且还会预先渲染文本框字段phonenumber。然后我对这个phonenumber文本框进行了更改,每次弹出警报框。即事件似乎一直在发射。

场景2 - 问题

在方案1之后,如果用户更改了国家/地区选择,则有一个ajaxpostback,当表单完成渲染时,当我在文本框中进行另一次更改时,该事件不会再触发,任何想法为什么?

代码: 事件监听器注册

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>

<script>
    $(document).ready(function () {
        document.getElementById("ctl00_ContentPlaceHolder1_officePhone_txtInput").addEventListener("change", phoneNumberParser, true);
        document.getElementById("ctl00_ContentPlaceHolder1_country_cbInput_Input").addEventListener("change", triggerCountryChange);
        //alert(document.getElementById("ctl00_ContentPlaceHolder1_officePhone_txtInput").value);
        //$("ctl00_ContentPlaceHolder1_officePhone_txtInput").bind("onchange", phoneNumberParser);
    });
          </script>

onChange code

<script>
var selectedcountrycodeval;

    function triggerCountryChange() {


        //var phoneNumber = document.getElementById("ctl00_ContentPlaceHolder1_officePhone_txtInput").value;
        //alert(phoneNumber);
        //ctl00$ContentPlaceHolder1$country$cbInput_Input  country name input tag
        var regionCode = document.getElementById("ctl00_ContentPlaceHolder1_country_cbInput_Input").value;
        alert(regionCode);
        regionCode = getCountry(regionCode);
        selectedcountrycodeval = regionCode;
        alert(regionCode);
        //document.getElementById("ctl00_ContentPlaceHolder1_officePhone_txtInput").addEventListener("change", phoneNumberParser);
        //alert(document.getElementById("ctl00_ContentPlaceHolder1_officePhone_txtInput").addEventListener);
        //document.getElementById("ctl00_ContentPlaceHolder1_country_cbInput_Input").addEventListener("change", triggerCountryChange);
    }
    function phoneNumberParser() {

        alert(selectedcountrycodeval);
        var phoneNumber = document.getElementById("ctl00_ContentPlaceHolder1_officePhone_txtInput").value;
        alert(phoneNumber);
}
</script>

表格值

国家

<INPUT style="WIDTH: 220px" 
      id=ctl00_ContentPlaceHolder1_country_cbInput_Input 
      class=ComboBoxInput_WindowsXP tabIndex=1 value="United Kingdom" 
      name=ctl00$ContentPlaceHolder1$country$cbInput_Input></INPUT>

电话

<INPUT style="WIDTH: 221px" 
      id=ctl00_ContentPlaceHolder1_officePhone_txtInput class=inputTextBox 
      tabIndex=1 value="+44 (20) 8222-2662" maxLength=64 
      name=ctl00$ContentPlaceHolder1$officePhone$txtInput >

1 个答案:

答案 0 :(得分:1)

看起来您似乎在刷新表单后添加了电话号码输入。对于这种情况,最好委派事件。

$(document).on('change' , '[id*="officePhone_txtInput"]', phoneNumberParser );