- 浏览: 36658 次
文章分类
- 全部博客 (35)
- java (36)
- Toast to C (1)
- Java二进制指令代码解析 (1)
- CHAR (1)
- varchar以及varchar2的区别 (1)
- Java学习笔记(二)----JBoss发展现状 (1)
- Enum的策略模式 (1)
- j2EE开发群 欢迎加入该群一起学习 群号:172429747 (1)
- clipRect 介绍 (1)
- 认识Java程序之对象间消息传递 (1)
- Android的Location功能代码 (1)
- Android的Activity之间的通信 (1)
- 关于提高自己JAVA水平的十大技术讨论(转) (1)
- 推荐三本书 (1)
- C#打印DataGrid中的数据 (1)
- 注意新技术的风险是否会超过获得成功的几率 (1)
- MapXtreme2004代码 简单专题图的显示 (1)
- 在网页中插入RM视频文件的历程 (1)
- 《使用 Microsoft .NET 的企业解决方案模式》读书笔记2 (1)
- xml格式字符串与java对象互转 (1)
- 手机wifi传文件的一简单代码 (1)
- HOWTO: Disable HTTP Methods in Apache (1)
- SQL 笔试题(摘) (1)
- java的ProcessBuilder阻塞问题 (1)
- 现在在郑州做java开发想去深圳 (1)
- Could not find a JavaScript runtime (1)
- 构造方法,重载,多个,无参,参数,this,super (1)
- Servlet多线程 (1)
- 如何使SOLR系统自动AUTO COMMIT (1)
- Linux下Mysql表名区分大小写 (1)
- 好玩的游戏合集~~ (1)
- HashMap源码分析 (1)
- 以一个枢纽值二分一个数组 (1)
最新评论
-
liuyes:
写的有点乱呀
HashMap源码分析 -
chenglinjava:
来北京吧!!!
现在在郑州做java开发想去深圳
<div>本文转自:http://www.cnblogs.com/ly5201314/archive/2009/03/04/1402993.html<br><p>javascript:只能输入数字(ie、ff)</p><p>为了解决只能输入数字的问题,网上有许多资料,现归拢一下。</p><p><strong> 一、不带负号的输入</strong></p><p>这里,没有解决“正负号”的问题。</p><p>由于“正负号”必须出现在数字的最前端,因此,必须要判断当前光标所在的位置是否在输入文本框的首位。</p><table style="border-right: 1px solid; border-top: 1px solid; border-left: 1px solid; border-bottom: 1px solid; background-color: #e0e0e0;" cellspacing="0" cellpadding="0" width="100%" border="1"><tr><td><p><script language="javascript" type="text/javascript" ><br><!--<br>//调用方式:onkeydown = "digitinput(this,event);"<br>function digitinput(el,ev) {<br>//8:退格键、46:delete、37-40: 方向键<br>//48-57:小键盘区的数字、96-105:主键盘区的数字<br>//110、190:小键盘区和主键盘区的小数<br>//189、109:小键盘区和主键盘区的负号</p><p> var event = ev || window.event; //ie、ff下获取事件对象<br> var currentkey = event.charcode||event.keycode; //ie、ff下获取键盘码<br><br> //小数点处理<br> if (currentkey == 110 || currentkey == 190) {<br> if (el.value.indexof(".")>=0) <br> if (window.event) //ie<br> event.returnvalue=false; //e.returnvalue = false;效果相同.<br> else //firefox<br> event.preventdefault();</p><p> } else <br> if (currentkey!=8 && currentkey != 46 && (currentkey<37 || currentkey>40) && (currentkey<48 || currentkey>57) && (currentkey<96 || currentkey>105))<br> if (window.event) //ie<br> event.returnvalue=false; //e.returnvalue = false;效果相同.<br> else //firefox<br> event.preventdefault();</p><p>}<br>--></p><p></script></p></td></tr></table><p><strong> 二、带负号的输入</strong></p><p> 判断带负号的输入,则必须要知道光标的位置,也就是说,只有当光标在最前端时,负号才有效。</p><table style="border-right: 1px solid; border-top: 1px solid; border-left: 1px solid; border-bottom: 1px solid; background-color: #e0e0e0;" cellspacing="0" cellpadding="0" width="100%" border="1"><tr><td><p><script language="javascript" type="text/javascript" ><br><!--<br>//调用方式:onkeydown = "digitinput(this,event);"<br>function digitinput(el,ev) {<br>//8:退格键、46:delete、37-40: 方向键<br>//48-57:小键盘区的数字、96-105:主键盘区的数字<br>//110、190:小键盘区和主键盘区的小数<br>//189、109:小键盘区和主键盘区的负号</p><p> var event = ev || window.event; //ie、ff下获取事件对象<br> var currentkey = event.charcode||event.keycode; //ie、ff下获取键盘码<br><br> //小数点处理<br> if (currentkey == 110 || currentkey == 190) {<br> if (el.value.indexof(".")>=0) <br> if (window.event) //ie<br> event.returnvalue=false; //e.returnvalue = false;效果相同.<br> else //firefox<br> event.preventdefault();</p><p> } else<br> //负号处理<br><strong> if (currentkey == 189 || currentkey == 109) {<br> if (getposition(el)>0 || el.value.indexof("-")>=0)<br></strong> if (window.event) //ie<br> event.returnvalue=false; //e.returnvalue = false;效果相同.<br> else //firefox<br> event.preventdefault();<br> } else<br> if (currentkey!=8 && currentkey != 46 && (currentkey<37 || currentkey>40) && (currentkey<48 || currentkey>57) && (currentkey<96 || currentkey>105))<br> if (window.event) //ie<br> event.returnvalue=false; //e.returnvalue = false;效果相同.<br> else //firefox<br> event.preventdefault();</p><p>}<br>/**<br> * 获取光标所在的字符位置<br> * @param obj 要处理的控件, 支持文本域和输入框<br> * @author hotleave<br> */<br>function getposition(obj){<br> var result = 0;<br> if(obj.selectionstart){ //非ie浏览器<br> result = obj.selectionstart<br> }else{ //ie<br> var rng;<br> if(obj.tagname == "textarea"){ //如果是文本域<br> rng = event.srcelement.createtextrange();<br> rng.movetopoint(event.x,event.y);<br> }else{ //输入框<br> rng = document.selection.createrange();<br> }<br> rng.movestart("character",-event.srcelement.value.length);<br> result = rng.text.length;<br> }<br> return result;<br>}</p><p>--></p><p></script></p></td></tr></table><p>getposition(obj)函数,是一个获取光标位置的通用函数。</p><p>为了减少传入的参数,事件对象是可以通过事件获取的:</p><table style="border-right: 1px solid; border-top: 1px solid; border-left: 1px solid; border-bottom: 1px solid; background-color: #ccffff;" cellspacing="0" cellpadding="0" width="100%" border="1"><tr><td>var el = window.event.srcelement||ev.target;</td></tr></table><p>只需将传digitinput(el,ev)的第一句加上上面这条语句,并且将传入参数只有ev一个即可,这样,减少了传入值。</p><p><strong> 三、扩展</strong></p><p> 我们可以增加一个传入的参数值,用于限定允许输入的数字条件:</p><p>1:允许正整数;2、允许正小数;3、允许负整数;4、允许负小数。</p><p>当然,传入一个正则表达式也可以实现。</p><div style="border-right: #cccccc 1px solid; padding-right: 5px; border-top: #cccccc 1px solid; padding-left: 4px; font-size: 13px; padding-bottom: 4px; border-left: #cccccc 1px solid; width: 98%; padding-top: 4px; border-bottom: #cccccc 1px solid; background-color: #eeeeee;"><img alt="" src="http://www.cnblogs.com/images/outliningindicators/none.gif" align="top"><span style="color: #000000;">functiononlynum()<br><img id="codehighlighter1_20_477_open_image" src="http://www.cnblogs.com/images/outliningindicators/expandedblockstart.gif" align="top"><img id="codehighlighter1_20_477_closed_image" style="display: none;" src="http://www.cnblogs.com/images/outliningindicators/contractedblock.gif" align="top"></span><span id="codehighlighter1_20_477_open_text"><span style="color: #000000;">{<br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #0000ff;">if</span><span style="color: #000000;">(</span><span style="color: #000000;">!</span><span style="color: #000000;">((</span><span style="color: #0000ff;">event</span><span style="color: #000000;">.keycode</span><span style="color: #000000;">>=</span><span style="color: #000000;">48</span><span style="color: #000000;">&&</span><span style="color: #0000ff;">event</span><span style="color: #000000;">.keycode</span><span style="color: #000000;"><=</span><span style="color: #000000;">57</span><span style="color: #000000;">)<br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #000000;">||</span><span style="color: #000000;">(</span><span style="color: #0000ff;">event</span><span style="color: #000000;">.keycode</span><span style="color: #000000;">>=</span><span style="color: #000000;">96</span><span style="color: #000000;">&&</span><span style="color: #0000ff;">event</span><span style="color: #000000;">.keycode</span><span style="color: #000000;"><=</span><span style="color: #000000;">105</span><span style="color: #000000;">)<br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #000000;">||</span><span style="color: #000000;">(</span><span style="color: #0000ff;">event</span><span style="color: #000000;">.keycode</span><span style="color: #000000;">==</span><span style="color: #000000;">8</span><span style="color: #000000;">)</span><span style="color: #008000;">//</span><span style="color: #008000;">退格</span><span style="color: #008000;"><br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #000000;"></span><span style="color: #000000;">||</span><span style="color: #000000;">(</span><span style="color: #0000ff;">event</span><span style="color: #000000;">.keycode</span><span style="color: #000000;">==</span><span style="color: #000000;">46</span><span style="color: #000000;">)</span><span style="color: #008000;">//</span><span style="color: #008000;">del</span><span style="color: #008000;"><br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #000000;"></span><span style="color: #000000;">||</span><span style="color: #000000;">(</span><span style="color: #0000ff;">event</span><span style="color: #000000;">.keycode</span><span style="color: #000000;">==</span><span style="color: #000000;">27</span><span style="color: #000000;">)</span><span style="color: #008000;">//</span><span style="color: #008000;">esc</span><span style="color: #008000;"><br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #000000;"></span><span style="color: #000000;">||</span><span style="color: #000000;">(</span><span style="color: #0000ff;">event</span><span style="color: #000000;">.keycode</span><span style="color: #000000;">==</span><span style="color: #000000;">37</span><span style="color: #000000;">)</span><span style="color: #008000;">//</span><span style="color: #008000;">左</span><span style="color: #008000;"><br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #000000;"></span><span style="color: #000000;">||</span><span style="color: #000000;">(</span><span style="color: #0000ff;">event</span><span style="color: #000000;">.keycode</span><span style="color: #000000;">==</span><span style="color: #000000;">39</span><span style="color: #000000;">)</span><span style="color: #008000;">//</span><span style="color: #008000;">右</span><span style="color: #008000;"><br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #000000;"></span><span style="color: #000000;">||</span><span style="color: #000000;">(</span><span style="color: #0000ff;">event</span><span style="color: #000000;">.keycode</span><span style="color: #000000;">==</span><span style="color: #000000;">16</span><span style="color: #000000;">)</span><span style="color: #008000;">//</span><span style="color: #008000;">shift</span><span style="color: #008000;"><br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #000000;"></span><span style="color: #000000;">||</span><span style="color: #000000;">(</span><span style="color: #0000ff;">event</span><span style="color: #000000;">.keycode</span><span style="color: #000000;">==</span><span style="color: #000000;">9</span><span style="color: #000000;">)</span><span style="color: #008000;">//</span><span style="color: #008000;">tab</span><span style="color: #008000;"><br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #000000;">)<br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top">)<br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #008000;">//</span><span style="color: #008000;">考虑小键盘上的数字键</span><span style="color: #008000;"><br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/inblock.gif" align="top"></span><span style="color: #000000;"></span><span style="color: #0000ff;">event</span><span style="color: #000000;">.returnvalue</span><span style="color: #000000;">=</span><span style="color: #0000ff;">false</span><span style="color: #000000;">;<br><img alt="" src="http://www.cnblogs.com/images/outliningindicators/expandedblockend.gif" align="top">}</span></span><span style="color: #000000;"> <br></span>
发表评论
-
以一个枢纽值二分一个数组
2012-02-08 15:17 872划分算法由两个指针开始,分别指向数组的两头。在左边的指 ... -
HashMap源码分析
2012-02-08 13:33 1125[size=medium;]HashMap源码分析 ... -
好玩的游戏合集~~
2012-02-07 16:19 1056因为刚接触windows phone不久,自己平时收藏 ... -
Linux下Mysql表名区分大小写
2012-02-04 13:58 11501、Linux下mysql安装完后是默认:区分表名的 ... -
如何使SOLR系统自动AUTO COMMIT
2012-02-03 16:49 911转自:http://blog.csdn.net/thu ... -
Servlet多线程
2012-02-03 13:24 926? <div class="Se ... -
构造方法,重载,多个,无参,参数,this,super
2012-02-02 14:29 2420构造方法名([参数列表]){ ? [this([参数 ... -
Could not find a JavaScript runtime
2012-02-02 13:19 778My Rails3.1 app worked fine ... -
现在在郑州做java开发想去深圳
2012-01-31 14:43 919 &nb ... -
java的ProcessBuilder阻塞问题
2011-12-28 18:08 1358<span style="color: ... -
SQL 笔试题(摘)
2011-12-28 11:29 1007(1)表名:购物信息 购物人 商品名称 ... -
HOWTO: Disable HTTP Methods in Apache
2011-12-21 14:59 925<h3 class="entry-h ... -
手机wifi传文件的一简单代码
2011-12-20 13:39 1318手机与笔记本传文件的方法有很多种,如果不方便使用蓝牙 ... -
xml格式字符串与java对象互转
2011-12-20 11:34 1439import java.lang.reflect. ... -
《使用 Microsoft .NET 的企业解决方案模式》读书笔记2
2011-12-19 10:39 718第2章 组织模式 面向对象编程的基本元素是类。但是,如 ... -
在网页中插入RM视频文件的历程
2011-12-19 08:59 988俺最早想到的是直接利用Frontpage2003,看看 ... -
MapXtreme2004代码 简单专题图的显示
2011-12-15 14:24 716MapControl1.Map.Clear();< ... -
注意新技术的风险是否会超过获得成功的几率
2011-12-14 18:28 365</span></span> ... -
C#打印DataGrid中的数据
2011-12-14 16:59 1343<span style="" ... -
推荐三本书
2011-12-13 15:19 702推荐最近一直在看的三本书,很好,真的很好,别的也没什么 ...
相关推荐
- **应用场景**:适合需要精确控制输入的情况,比如数字输入框。 #### 6. 网页无法被另存为 - **代码示例**: ```javascript if (window == top) { top.location.href = "frames.htm"; } ``` - **解释**:...
本文将详细介绍如何使用JavaScript来检查邮箱地址的有效性,适用于IE5+、Firefox 1.06及Opera 7+等主流浏览器。 首先,我们需要理解一个有效的邮箱地址应该遵循的格式。根据RFC 5322,一个标准的电子邮件地址由两...
- **应用场景**:当希望用户只能输入英文字符时使用。 ### 8. 检测是否在框架内打开页面 - **技巧描述**:通过比较`window`对象与`top`对象,判断当前页面是否在一个框架内打开。 - **代码示例**: ```html ...
项目描述中提到,这个验证码系统已在IE、FF、Chrome、Opera和Safari等多个浏览器上测试通过,这意味着代码具有良好的浏览器兼容性。为了实现这一点,可能需要使用像jQuery这样的库来处理跨浏览器差异,或者使用特性...
根据提供的文件信息,我们可以总结出以下JavaScript相关的知识点: ### 1. 禁止右键菜单 ```javascript oncontextmenu="window.event.returnValue=false" ``` 或者 ```html ...
jquery限制文本框只能输入数字,兼容IE、chrome、FF(表现效果不一样),示例代码如下: 代码如下: $(“input”).keyup(function(){ //keyup事件处理 $(this).val($(this).val().replace(/\D|^0/g,”)); }).bind(...
jQuery的轻量级特性(压缩后仅21k)以及对CSS3和多浏览器的良好支持(包括IE 6.0+,FF 1.5+,Safari 2.0+,Opera 9.0+)使其成为开发者的首选工具。 jQuery插件是jQuery生态系统的重要组成部分,它们扩展了jQuery的...
`maxlength="3"`确保每个输入框最多只能输入三位数字,`size="5"`设定了输入框的宽度,使其看起来更整洁。结合`onkeyup`事件,当输入达到三个字符时,代码会自动选中(或聚焦)下一个输入框,便于用户连续输入多个...
本文介绍了一个JavaScript的方法,它能够实现将网页中的表格数据导出为Excel文件的功能,并确保该方法可以在微软的IE浏览器和Mozilla的火狐(Firefox)浏览器中同时使用。 ### 1. 导出原理与兼容性问题 传统上,将...
/>` 是一个可以输入数字的文本框,用于输入零件数量。这些事件处理函数(如`onkeypress`和`onkeyup`)是JavaScript的一部分,用于处理用户输入时的逻辑。 现在转向JavaScript部分,`addEvent`函数是用来实现事件...
1、 调整图片大小,不走形(FF IE 兼容)/ 剪切图片(overflow:hidden) 2、 控制textarea区域文字数量 3、 点击显示新窗口 4、 input框自动随内容自动变长 5、 添加收藏夹 6、 设置首页 7、 Jquery + Ajax ...
- 输入验证部分提示用户输入有效的数字,并在输入非法值时给出警告,这是前端数据验证的一个实例。 5. JavaScript中的一些不规范用法: - 代码段中存在一些不规范或已弃用的JavaScript用法,例如使用`var`关键字...
- **应用场景**:适用于需要确保页面只能在特定框架中打开的情况,如企业内部管理系统等。 #### 八、防止页面被其他网站嵌入为框架内容 - **代码实现**: ```javascript if (top.location != self.location) { ...
`execCommand` 是一个在早期浏览器中广泛使用的非标准 JavaScript 方法,主要用于实现富文本编辑器的功能。通过调用 `document.execCommand`,开发者能够轻松地执行一系列与编辑文档相关的操作,如格式化文本、插入...
Javascript小技巧一箩筐 事件源对象 event.srcElement.tagName event.srcElement.type 捕获释放 event.srcElement.setCapture(); event.srcElement.releaseCapture(); 事件按键 event.keyCode ...
- 可以更好地与JavaScript变量命名区分开来(JavaScript变量命名通常使用下划线)。 2. **避免滥用ID**:虽然ID具有更高的特异性,但在实际项目中应尽量减少使用,因为ID只能在一个文档中出现一次。相比之下,类...
此属性可以禁用输入法在输入框中的功能,适用于需要控制输入格式的场景,如数字输入等。 ### 8. 跳转至框架页 ```html <script language="JavaScript"> if(window==top) top.location.href="frames.htm"; ``` 这...
这对于需要用户输入英文或数字的场景很有用。 #### 5. 框架保护 **代码示例**: ```html <script language="javascript"> if (window == top) { top.location.href = "frames.htm"; } ``` **知识点解析**:该...