js数字输入框(包括最大值最小值限制和四舍五入)
js数字输入框(包括最大值最小值限制和四舍五入)
发布时间:2016-12-30 来源:查字典编辑
摘要:由于原文已经介绍的很好了,现在只是一些翻译和小小的补充。例子复制代码代码如下:DemojQuery(function($){$(':text...

由于原文已经介绍的很好了,现在只是一些翻译和小小的补充。

例子

复制代码 代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >

<head>

<title>Demo</title>

<script type="text/javascript" src="jquery-1.2.6.min.js"></script>

<script type="text/javascript" src="autoNumeric.js"></script>

<script type="text/javascript">

jQuery(function($) {

$(':text').focus(function(){

$(':text').autoNumeric();

});

});

var change = function(){

//Change the rule.

$(":text[id$='text1']").attr('alt','p2c3p0s');

//Clear the text

$(":text[id$='text1']").val('');

$("span[id$='lblrule']").text('格式:99(范围为0-99)');

}

var show = function(){

//format the text2 and text3.

var convertInput = $.fn.autoNumeric.Strip($(":text[id$='text1']").attr("id"));

$(":text[id$='text2']").val(convertInput);

$(":text[id$='text3']").val($.fn.autoNumeric.Format($(":text[id$='text3']").attr("id"), convertInput));

}

</script>

</head>

<body>

<table>

<tr>

<td>

<span id='lblrule' >格式:9999.99(范围为0-9999.99)(动态修改alt属性):</span>

</td>

<td>

<input id="text1" value="" type="text" alt="p4c3p2s" size="25" />

<input type="button" value='格式化显示' />

<input type="button" value='改变属性'/>

</td>

</tr>

<tr>

<td>

<span id='lbl1' >利用Strip()方法去掉了格式,如'1,123'变为'1123'(仅显示第一个文本框内容):</span>

</td>

<td>

<input id="text2" value="" type="text" readonly="readonly" alt="p4c3p0S" size="25" />

</td>

</tr>

<tr>

<td>

<span id='lbl2' >格式化数字,这里做的是四舍五入取整,如'5.6'变为'6'(仅显示第一个文本框内容):</span>

</td>

<td>

<input id="text3" value="" type="text" readonly="readonly" alt="p4c3p0S" size="25" />

</td>

</tr>

</table>

</body>

</html>

本plugin的特性:

.只能输入数字,小数分隔符(包括小数点),负号.

.支持在同一个页面上每个text input的不同输入格式,也就是说可以对页面上每一个输入框进行自定义设置.

.九种不同的数字修约规则(就是四舍五入那些)

.可以分别针对整数和小数设置最大值,最小值(很好用)

.输入值可以只为正数,也可以正负数.

.只有小数和零时,前导符可以为零。不过如输入数为"900"时,删掉"9"它会保留00.

.支持粘贴,不过粘贴文字时会变成"0.00".

.公共方法Strip()可以去掉格式化.

.公共方法Format()可以将需要的值进行格式化.

关于alt属性中的设置:

alt中一共有7个字符,分别代表了7个格式化属性:

第一个:值为'p'(只能输入正数)或者'n'(正负都可以输入)

第二个:值为0-9,分别代表小数点分隔符左边的位数.(当为'0'时可以输入15位整数)

第三个:用做数字分组的分隔符(就是千分位等等用的分隔符)

a:单引号或撇号(计时和角度时可以用)

c:逗号(默认)

p:句号(如果小数点的分隔符也是句号会有冲突)

s:空格号

x:无

第四个:值为2,3(默认),4,用作数字分组的数字个数(如'3'的话为'123,123','4'的话为'12,3123','2'的时候好像是印度那边有这种分法,看原文作者写的)

第五个:小数点的分隔符.值有c(逗号)和p(句号),p为默认.

第六个:小数位的个数

:不允许输入小数,也就是说只能输入整数

-9:小数位数(默认为2,如'1.23')

a-Z:包括大小写,它会找id为'dp[a-Z]'的数字输入框,并将里面的数字作为小数的位数,也就是说可以动态修改小数位数.

第七个:九种不同的数字修约规则

S = Round-Half-Up Symmetric (默认,一般四舍五入就用它了)

A = Round-Half-Up Asymmetric

s = Round-Half-Down Symmetric

a = Round-Half-Down Asymmetric

B = Round-Half-Even "Bankers Rounding"(银行家算法?没用过)

U = Round Up "Round-Away-From-Zero"(最大整数时用这个,当然不仅仅是整数范畴,可以精确到小数位)

D = Round Down "Round-Toward-Zero"(最小整数时用这个)

C = Round to Ceiling "Toward Positive Infinity"

F = Round to Floor "Toward Negative Infinity"

关于这个数字修约规则有一篇英文文章,可以参考。 http://www.diycalculator.com/popup-m-round.shtml 还有一些关于粘贴的特性和数字修约的一些例子就不一一介绍了。有兴趣的可以上作者的原文看看。 非常感谢作者能提供一个这么好的Jquery plugin.测试代码打包http://xiazai.jb51.net/200911/yuanma/numeric-demo.rar

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类