威凡网全力打造:网页编程、软件开发编程、平面设计、服务器端开发、操作系统等在线学习平台!学编程,上威凡网!
JSP教程>> JSP基础教程 JSP高级教程 JSP常见问题
当前位置:首页 > JSP教程 > JSP常见问题
上一节 下一节
 jsp要实现屏蔽退格键问题探讨
今天涉及到一个问题,在jsp中的查询条件中,有文本框可输入筛选条件,也有下拉框选择筛选条件。输入框中内容可按“backspace”键进行删除,但是下拉框中需要屏蔽backspace功能,否则就回执行页面的回退功能。代码如下
复制代码 代码如下:

<td width="350px;">企业名称: 
<input type="text" name="filter_psname" id="psname" size="40"/>
</td>
<td width="200px;">区域: 
<select name="filter_regioncode" id="regionname" theme="simple" />
</td>
<td>
<s:radio onclick="query();" name="filter_status" theme="simple" ></s:radio>
</td>
<td valign="middle" align="center">
<img src="${ctx}/common/img/icons/icon403a3.gif" height="20" />查询

</td>

在网上找了一段屏蔽退格键的代码如下
复制代码 代码如下:

$(document).keydown(function (e) {
var doprevent;
if (e.keycode == 8) {
var d = e.srcelement || e.target;
if (d.tagname.touppercase() == 'select') {
doprevent = d.readonly || d.disabled;
}
else
doprevent = true;
}
else
doprevent = false;
if (doprevent)
e.preventdefault();
});

发现有如下问题:
下拉框d.tagname获取的的标签名称也是input。故实现不了上述需求。
仔细研究了一下,下了如下代码
复制代码 代码如下:

//屏蔽下拉框的退格键操作
$(document).keydown( function(e)
{
//获取键盘的按键code
var k=e.keycode;
//获取操作的标签对象
var obj=e.target || e.srcelement;
//获取对象的只读属性的值
var vreadonly = obj.getattribute('readonly');
//如果按键为“backspace”并且标签对象的只读属性不为空时return false(select 标签默认 readonly=“readonly”)
if(k==8 && vreadonly!=null){
return false;
}
});

实现了上述需求,应该还有更好的办法,希望朋友们看到能够给予提示或者互相讨论。

申明:本教程内容由威凡网编辑整理并提供IT程序员分享学习,如文中有侵权行为,请与站长联系(QQ:254677821)!
上一节 下一节
相关教程  
其他教程  
JSP基础教程
JSP高级教程
JSP常见问题

违法和不良信息举报中心】邮箱:254677821@qq.com
Copyright©威凡网 版权所有 苏ICP备2023020142号
站长QQ:254677821