最近做的一些项目,经常遇到输入框检查的需求,最常见的是即时搜索,今天好好小结一下。

        ==================================================================

        即时搜索的方案:

        (1)change事件    饿。。。。。   触发事件必须满足两个条件:

            a)当前对象属性改变,并且是由键盘或鼠标事件激发的(脚本触发无效)
            b)当前对象失去焦点(onblur)
 

        (2)keypress  恩,还好。。。。。就是能监听键盘事件,鼠标复制黏贴操作他就无能为力的赶脚了。。。。。

        (3)propertychange(ie)和input事件

           +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

            input是标准的浏览器事件,一般应用于input元素,当input的value发生变化就会发生,无论是键盘输入还是鼠标

            黏贴的改变都能及时监听到变化

            propertychange,只要当前对象属性发生改变。(IE专属的)

            感觉找到了真爱。。。。。但是

            ======

              oninput 和 onpropertychange 这两个事件在 IE9 中都有个小BUG,

              那就是通过右键菜单菜单中的 剪切 和 删除 命令删除内容的时候不会触发,

              而 IE 其他版本都是正常的,目前还没有很好的解决方案。

            =======

            不过 input & propertychange 仍然是即时搜索比较好的方案

        ==========================================================================

        实践了一下

        //格式化显示卡号

        var cnAdvanceChangeHandle = function(e){

          var value = $(this).val();
            $(this).val(format(value, 4, 19));

        };

        //格式化显示卡号,ie处理

        function changeHandle(target, value){

          $(target).val(value);

        }

        //step参数是设置卡号每隔几个数字空一格,contrLen是设置只能输入的字符个数

        var cardNoChangeHandle = function(step, contrLen){

          //中间变量,保存input的值和当前值比较,不相同才要进行格式化处理

          //避免内存溢出异常

          var tempValue;

          return function(e){

            var value = $(this).val();

            if(value != tempValue){

              value = format(value, step, contrLen);

              tempValue = value;

              changeHandle(this, value);

            }

          };

        };

        var cnHandle = cnChangeHandle(4, 19);

        //判断浏览器版本,是ie6,7,8

        !$.support.leadingWhitespace && $(".card-no").bind("propertychange", cnHandle );

        //其他高级浏览器

        $(document).delegate(".card-no", "input", cnAdvanceChangeHandle);

        

        eg:

        

总结一下 input propertychange的更多相关文章

  1. 巧用 即刻搜索事件 input propertychange 监听输入框字数

    实时监听输入框的字数,大于200时,不再输入. 即时搜索: propertychange(ie)和input事件(常用) input是标准的浏览器事件,一般应用于input元素,当input的valu ...

  2. input propertyChange

    結合 HTML5 標準事件 oninput 和 IE 專屬事件 onpropertychange 事件來監聽輸入框值變化. oninput 是 HTML5 的標準事件,對於檢測 textarea, i ...

  3. input propertychange(1)

    input type=“text” 通过js改变输入框的value值是不会出发input propertychange事件

  4. 'input propertychange' 当输入框文字改变时触发的事件!

    $('.amount_input').bind('input propertychange', function() { console.log(2); $('.list label').remove ...

  5. 即时反应的input和propertychange方法

    在web开发中,我们有时会需要动态监听输入框值的变化,当使用onkeydown.onkeypress.onkeyup作为监听事件时,会发现一些复制粘贴等操作用不了,同时,在处理组合快键键的时候也很麻烦 ...

  6. input实时监听(input oninput propertychange onpropertychange)

    本文实例讲述了js与jquery实时监听输入框值的oninput与onpropertychange方法.分享给大家供大家参考.具体如下: 最近做过一个项目,需求是下拉框里自动匹配关键字,具体细节是实时 ...

  7. input 输入框 propertychange

    做搜索功能的时候,经常遇到输入框检查的需求,最常见的是即时搜索,今天好好小结一下. 即时搜索的方案: (1)change事件    触发事件必须满足两个条件: a)当前对象属性改变,并且是由键盘或鼠标 ...

  8. input事件在进行模糊搜索时,用到的即时监测input的值变化的方法(即时搜索的input和propertychange方法)

    做搜索功能的时候,经常遇到输入框检查的需求,最常见的是即时搜索,今天好好小结一下. 即时搜索的方案: (1)change事件    触发事件必须满足两个条件: a)当前对象属性改变,并且是由键盘或鼠标 ...

  9. 使input文本框随其中内容而变化长度的方法

    最近在做商城的前端界面,遇到一个问题,就是使input的宽度能随着输入的内容而跟着变化,刚开始的时候用的是change事件,但是change事件要失去焦点之后才会出现效果,但是我要的是能实现边输入边改 ...

随机推荐

  1. VS大视野

    vs的本质:他是微软公司的员工一起开发的一个项目: 既然是项目:那么就是用编程语言编出来的! 用的是C# C#有他的特点:继承,封装,多态!等 我们在使用vs的时候,为什么可以使用很多的里面已经存在的 ...

  2. python 实现文件下载

    Requests库,高度封装的http库 import requests url = 'http://down.sandai.net/thunder9/Thunder9.0.18.448.exe' f ...

  3. Lua 中string.gsub(sourceString, pattern, replacementString) 返回值有两个

    这阵子在学习lua,今天看到string操作,书中描述string.gsub(sourceString, pattern, replacementString)返回一个字符串,但是我在实际操作中却发现 ...

  4. js在IE和FF下的兼容性问题

    本文出自前端档案,以作学习参考之用.自己也补充了一些内容 长久以来JavaScript兼容性一直是Web开发者的一个主要问题.在正式规范.事实标准以及各种实现之间的存在的差异让许多开发者日夜煎熬.为此 ...

  5. mfc 调用Windows的API函数实现同步异步串口通信(源码)

    在工业控制中,工控机(一般都基于Windows平台)经常需要与智能仪表通过串口进行通信.串口通信方便易行,应用广泛. 一般情况下,工控机和各智能仪表通过RS485总线进行通信.RS485的通信方式是半 ...

  6. http请求报错

    手机端上传base64位图片java后台接受 手机端post方式发送 后台报错: Error parsing HTTP request header Note: further occurrences ...

  7. Java中引用类型变量,对象,值类型,值传递,引用传递 区别与定义

    一.Java中什么叫做引用类型变量?引用:就是按内存地址查询       比如:String s = new String();这个其实是在栈内存里分配一块内存空间为s,在堆内存里new了一个Stri ...

  8. install Hadoop

    Installing Java Hadoop runs on both Unix and Windows operating systems, and requires Java to beinsta ...

  9. 分析案例:应用服务无响应,任务管理器中发现大量w3wp僵尸进程----等待异构系统WebService返回值

    问题描述:       某二次开发的项目反馈,不定期出现应用服务器无响应的情况,登录服务器发现任务管理器中有大量的w3wp僵尸进程. 分析过程: 针对同一进程每隔15秒抓取dump,连续抓取3个,对比 ...

  10. H5摇一摇遇到的问题

    一.如何对摇晃效果进行反馈 刚开始的处理方式是,摇晃过程中不做任何处理,但后来反馈说这种效果不好,好像就没有摇动一样,如果声音也不响的话,就真的和什么都没发生一样. 后来想了想,加入摇晃过程动画,就像 ...