jquery 输入框数字限制插件

 更新时间:2009年11月10日 23:49:50   作者:  
jquery 输入框数字限制插件,需要的朋友可以参考下。
直接看代码:
复制代码 代码如下:

(function($){
var keyCode={
BACKSPACE: 8,
CAPS_LOCK: 20,
COMMA: 188,
CONTROL: 17,
DELETE: 46,
DOWN: 40,
END: 35,
ENTER: 13,
ESCAPE: 27,
HOME: 36,
INSERT: 45,
LEFT: 37,
// NUMPAD_ADD: 107,
// NUMPAD_DECIMAL: 110,
// NUMPAD_DIVIDE: 111,
// NUMPAD_ENTER: 108,
// NUMPAD_MULTIPLY: 106,
// NUMPAD_SUBTRACT: 109,
PAGE_DOWN: 34,
PAGE_UP: 33,
PERIOD: 190,
RIGHT: 39,
SHIFT: 16,
SPACE: 32,
TAB: 9,
UP: 38
}
var isControlCode=function(key){
for(name in keyCode){
if(keyCode[name]==key)
return true;
}
return false;
}
var number=function(event){
var t=this;
if(event.shiftKey)
return false;
var key=event.keyCode;
if(isControlCode(key))
return;
if(key<48 || key>105)
return false;
if(key>57 && key<96)
return false;
}
var ControlList={};
var control=Class.extend({
init:function(obj){
this.Event=[];
this.target=$(obj);
},
Add:function(settings){
var t=this;
t.Event.push(settings);
return t;
},
Bind:function(){
var t=this;
if(!t.target){
return;
}
t.target.each(function(){
var b=$(this);
b.bind("keydown",t.event.bind(t)).bind("keyup",t.event.bind(t));
if(jQuery.browser.msie)
{
b.bind("paste",t.event.bind(t));
}
else{
b.bind("input",t.event.bind(t));
}
});
},
getmethods:function(type){
var t=this;
var list=[];
$(t.Event).each(function(i,item){
if(!item.type || !item.method)
return;
if(item.type=="all"){
list.push(item.method);
}else
{
if(item.type==type){
list.push(item.method);
}
}
});
return list;
},
IsSuccess:function(list,event,obj){
var istrue=true;
for(var i=0;i<list.length;i++){
if(list[i].call(obj,event)===false)
{
istrue=false;
break;
}
}
return istrue;
},
event:function(ev){
var t=this;
var event=ev.originalEvent;
var obj=ev.target;
return t.IsSuccess(t.getmethods(ev.type),event,obj);
}
});
control.Add=function(obj,settings){
var con= ControlList[this.selector];
if(!con)
{
con=new control(obj);
ControlList[this.selector]=con;
con.Bind();
}
con.Add(settings);
return control;
}
$.fn.numberable=function(){
$(this).css("imeMode","disabled");
control.Add(this,{type:"keydown",method:number}).Add(this,{type:"keyup",method:number});
function repnumber(event){
var o= $(this);
if(o.val()){
o.val(o.val().replace(/[^\d]/g,""));
}
}
if(jQuery.browser.msie){
control.Add(this,{type:"paste",method:function(event){var o=this;
setTimeout(repnumber.bind(o,event),0);
}
});
}
else
{
control.Add(this,{type:"input",method:repnumber});
}
return this;
}
})(jQuery);

用法:
复制代码 代码如下:

$(".class").numberable();

这只是限制了数字,还可以扩展其他的功能,

相关文章

  • jquery.idTabs 选项卡使用示例代码

    jquery.idTabs 选项卡使用示例代码

    idTabs是基于Jquery编写封装的一个插件,主要用于实现选项卡功能,下面是它的具体使用
    2014-09-09
  • jQuery轮播图功能制作方法详解

    jQuery轮播图功能制作方法详解

    这篇文章主要介绍了jQuery轮播图功能制作方法,结合实例形式详细分析了jQuery轮播图实现原理、步骤与相关操作技巧,需要的朋友可以参考下
    2019-12-12
  • jQuery实现的自定义滚动条实例详解

    jQuery实现的自定义滚动条实例详解

    这篇文章主要介绍了jQuery实现的自定义滚动条,结合完整实例详细分析了jQuery自定义滚动条的实现步骤与相关操作技巧,并给出了jquery.jscroll.js插件的完整代码,需要的朋友可以参考下
    2016-09-09
  • jQuery文字轮播特效

    jQuery文字轮播特效

    本文给大家分享的是jQuery制作文字轮播的特效,非常的实用,属于作者原创代码,分享给大家
    2017-02-02
  • 使用JavaScript+canvas实现图片裁剪

    使用JavaScript+canvas实现图片裁剪

    这篇文章主要介绍了使用JavaScript+canvas实现图片裁剪的方法,需要的朋友可以参考下
    2015-01-01
  • jQuery实现点击图片翻页展示效果的方法

    jQuery实现点击图片翻页展示效果的方法

    这篇文章主要介绍了jQuery实现点击图片翻页展示效果的方法,涉及jQuery操作图片的操作技巧,非常具有实用价值,需要的朋友可以参考下
    2015-02-02
  • 使用jQuery实现简单的tab框实例

    使用jQuery实现简单的tab框实例

    下面小编就为大家带来一篇使用jQuery实现简单的tab框实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • jQuery实现简单评论功能

    jQuery实现简单评论功能

    这篇文章主要为大家详细介绍了jQuery实现简单评论功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • jquery仿QQ登录账号选择下拉框效果

    jquery仿QQ登录账号选择下拉框效果

    这篇文章主要为大家详细介绍了jquery仿QQ登录账号选择下拉框效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • 无法获取隐藏元素宽度和高度的解决方案

    无法获取隐藏元素宽度和高度的解决方案

    本文主要介绍了无法获取隐藏元素(display:none)宽度(width)和高度(height)的解决方案,具有很好的参考价值。下面跟着小编一起来看下吧
    2017-03-03

最新评论