只读文本框的onchange事件处理及struts标签不支持的标签属性处理办法

1.如果某个文本框为只读,通过触发其他事件为它设置值,但却需要在它的值改变后触发相应的操作。onchange不行,onchange需要文本框改变并失去焦点后才会触发,所以可以使用onpropertychange属性。

2.如果页面中文本框为struts标签,struts标签不支持onpropertychange属性,那么可以使用js定义,如下:

document.getElementById('xx').attachEvent('onpropertychange',function(){ //xx为文本框id
        alert(arguments.length);    
        for(var i=0;i<arguments.length;i++){    
            alert(arguments[i]);    
        }    
}); //该方法可写在页面onload事件中。



如下转载自:http://hi.baidu.com/tang_guangyao/item/bda3bdf4f4e9fb38e2e3bd8f

另参考:http://bbs.csdn.net/topics/370182154

onchange和onpropertychange的不同:


IE下,当一个HTML元素的属性改变的时候,都能通过 onpropertychange来即时捕获。
onchange在属性值改变时还必须使得当前元素失去焦点(onblur)才可以激活该事件。

了解这一点后我们发现onpropertychange的效果就是我们想要的,可是很遗憾,它只在IE下有效果。


oninput可以在firefox下代替onpropertychange,但是oninput只在用户输入值改变时触发(即value改变),并非所有属性改变时触发,而且,通过js改变value时,oninput不会触发。


下面一篇网上找到的文章可以在firefox下模范onpropertychange

---------------------------------------文章转载------------------------------------------------------------------------------------------------------------

实时监听js改变value,跨浏览器支持

有两个文本框,其中一个只读,另一个可以输入。要求在可输入文本框中输入文本时,只读文本框能够获得输入的值,且只读文本框旁边出现提示信息,实时显示只读文本框的内容。
这个功能看是简单,但其实并没有想象的那么简单。(注意,可输入框的处理没什么可讨论的,关键是只读框的处理)

一开始,我们一般会想到在只读文本框上运用onchange事件。一试,发现onchange根本没用,该事件是在文本框获得焦点,然后内容改变失去焦点后才触发的,现在在只读文本框上根本没有这些,它的内容是通过js改变的。于是,需要寻找另外的方法。

这时,在网上找到了onpropertychange事件。该事件在文本框属性改变时触发,不管是通过什么方式改变的。注意,是属性改变,而不仅仅是value改变。一试,果然好使。然而,这个事件是IE专有的。WEB开发,必须得考虑浏览器的兼容问题。于是继续摸索……

在网上有看到了另外一个事件:oninput。网上到处都是:fireFox中的该事件与IE中onpropertychange的事件等同。然而,我一试,发现根本不等同。oninput事件在fireFox中似乎没有起作用。经过一段时间测试,终于明白,原来oninput并非与onpropertychange等同(网上到处到处乱转贴,也不认真测试一下)。oninput只在用户输入值改变时触发(即value改变),并非所有属性改变时触发,而且,通过js改变value时,oninput不会触发。这下郁闷了。好不容易看到点希望,又再次陷入了失望,还好没有绝望……哎,浏览器兼容问题真是麻烦。

左思右想,总有又有了眉目。对于fireFox等浏览器,可以通过定时器检查只读文本框的内容是否改变。测试后,终于大功告成。下面把代码贴出来与大家分享。

在IE中的效果:



FireFox中的效果图:



另外,我还在google Chrome测试也成功了(跟fireFox一样的)。

HTML代码:

view plaincopy to clipboardprint?
<table> 
            <tr> 
                <td>此处值通过js设置:</td> 
                <td><input id="jsUserName" type="text" name="jsUserName" readonly/></td> 
            </tr> 
            <tr> 
                <td>此处输入值:</td> 
                <td><input id="userName" type="text" name="userName"/></td> 
            </tr> 
        </table> 
<table>
   <tr>
    <td>此处值通过js设置:</td>
    <td><input id="jsUserName" type="text" name="jsUserName" readonly/></td>
   </tr>
   <tr>
    <td>此处输入值:</td>
    <td><input id="userName" type="text" name="userName"/></td>
   </tr>
  </table>

JavaScript代码:

view plaincopy to clipboardprint?
$(function()  
        {  
            var jsUserName = "";  
            if($.browser.msie)  // IE浏览器  
            {  
                $("#userName").get(0).onpropertychange = setJsUserName;  
                $("#jsUserName").get(0).onpropertychange = handle;  
            }  
            else    // 其他浏览器  
            {  
                var intervalName;   // 定时器句柄  
                $("#userName").get(0).addEventListener("input",setJsUserName,false);  
                  
                // 获得焦点时,启动定时器  
                $("#userName").focus(function(){  
                    intervalName = setInterval(handle,1000);  
                });  
                // 失去焦点时,清除定时器  
                $("#userName").blur(function()  
                {  
                    clearInterval(intervalName);  
                });  
            }  
              
            // 设置jsUserName input的值  
            function setJsUserName()  
            {  
                $("#jsUserName").val($(this).val());  
            }  
              
            // jsUserName input的值改变时执行的函数  
            function handle()  
            {     
                // IE浏览器此处判断没什么意义,但为了统一,且提取公共代码而这样处理。  
                if($("#jsUserName").val() != jsUserName)  
                {  
                    $("#toolTip").remove();  
                    $("#jsUserName").parent().append("<span id='toolTip'>看到这里的信息表明,通过js改变input的值也能响应相应事件:<span  style="color:red;" mce_style="color:red;">" + $("#jsUserName").val() + "</span></span>");  
                    jsUserName = $("#jsUserName").val();  
                }  
            }  
        }); 
$(function()
  {
   var jsUserName = "";
   if($.browser.msie) // IE浏览器
   {
    $("#userName").get(0).onpropertychange = setJsUserName;
    $("#jsUserName").get(0).onpropertychange = handle;
   }
   else // 其他浏览器
   {
    var intervalName; // 定时器句柄
    $("#userName").get(0).addEventListener("input",setJsUserName,false);
    
    // 获得焦点时,启动定时器
    $("#userName").focus(function(){
     intervalName = setInterval(handle,1000);
    });
    // 失去焦点时,清除定时器
    $("#userName").blur(function()
    {
     clearInterval(intervalName);
    });
   }
   
   // 设置jsUserName input的值
   function setJsUserName()
   {
    $("#jsUserName").val($(this).val());
   }
   
   // jsUserName input的值改变时执行的函数
   function handle()
   { 
    // IE浏览器此处判断没什么意义,但为了统一,且提取公共代码而这样处理。
    if($("#jsUserName").val() != jsUserName)
    {
     $("#toolTip").remove();
     $("#jsUserName").parent().append("<span id='toolTip'>看到这里的信息表明,通过js改变input的值也能响应相应事件:<span  style="color:red;" mce_style="color:red;">" + $("#jsUserName").val() + "</span></span>");
     jsUserName = $("#jsUserName").val();
    }
   }
  });

说明:为了方便,js代码使用了jQuery。不使用是一样的。
另外,考虑性能问题,可以考虑何时启动定时器和清除定时器以及定时器延时时间。

总结:

1、onchange事件与onpropertychange事件的区别:
onchange事件在内容改变(两次内容有可能还是相等的)且失去焦点时触发;onpropertychange事件却是实时触发,即每增加或删除一个字符就会触发,通过js改变也会触发该事件,但是该事件IE专有。

2、oninput事件与onpropertychange事件的区别:
oninput事件是IE之外的大多数浏览器支持的事件,在value改变时触发,实时的,即每增加或删除一个字符就会触发,然而通过js改变value时,却不会触发;onpropertychange事件是任何属性改变都会触发的,而oninput却只在value改变时触发,oninput要通过addEventListener()来注册,onpropertychange注册方式跟一般事件一样。(此处都是指在js中动态绑定事件,以实现内容与行为分离)

3、oninput与onpropertychange失效的情况:
(1)oninput事件:a). 当脚本中改变value时,不会触发;b). 从浏览器的自动下拉提示中选取时,不会触发。
(2)onpropertychange事件:当input设置为disable=true后,onpropertychange不会触发。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值