一、 提交 与 重置 时的注意项
先看如下代码:
onsubmit ="return validate();" >
< table width ="100%" border ="0" cellpadding ="4" cellspacing ="0" class ="l_table_p" >
< tr >
< td bgcolor ="#DBF9DF" > </ td >
< td bgcolor ="#DBF9DF" align ="right" > 名 称: </ td >
< td colspan ="3" bgcolor ="#DBF9DF" >< input type ="text" name ="tagname" id ="tagname" style ="
width:150px;"
maxlength ="10" /></ td >
</ tr >
< tr >
< td colspan ="5" bgcolor ="#DBF9DF" >
< label >
< input type ="submit" value ="添加" class ="btn_c3" />
< input type ="reset" value ="重置" class ="btn_c3" />
</ label >
</ td >
</ tr >
</ table >
</ form >
以上就是一个表单, 请注意 重置的部分演示地址:http://你的IP/dev/err_case/2.jsp
问题: 在FF下,重置也会交表单, 解决办法: 去掉<label>
---------------------------------------------------------------------------------------------------------------------------------------------
二、IE6 onclick事件 要加 return false
$PF(this).submit() 的作用是提交表单
我们想单击超链接,来提交表 单, 在IE7与FF下都正常, 但在IE6下, 不能提交表单
要加return false , 如下
三 , 关于节点类型 在说一说
万维网联盟( W3C )定义 HTML DOM 标准节点有以下几种 ()
ELEMENT_NODE | 1 | 元素节点 |
ATTRIBUTE_NODE | 2 | 属性节点 |
TEXT_NODE | 3 | 文本节点 |
IE与FF 对 以上节点的 "理解" 有差异,如比我们写js : 对象.nextSibling , 来取得对象的下一个兄弟节点,
在IE中,只会取ELEMENT_NODE (元素节点), 忽略其它类型节点. FF会取得上面各种类型节点.
如:
<table>
<tr id="nst"><td></td></tr>(这里有换行,就是一个文本节点)
<tr><td></td></tr>
</table>
\-------------------------------------\-
<js>
var o=$('nst');
var next=o.nextSibling;
</js>
\--------------------------------------\-
结果:
IE中:next 是元素节点 (第二个<tr>)
FF中:next 是文本节点 (那个换行)
解决办法: 在base.js中有如下方法: 通过判断 nodeType == 1 来解决问题
// 获得下一个元素对象(nodeType=1)
function $NE(e)
{
e = e.nextSibling;
while (e && e.nodeType != 1){e = e.nextSibling;}
return e;
}
// 获得第一个元素对象(nodeType=1)
function $FE(e)
{
e = e.firstChild;
while (e && e.nodeType != 1){e = e.nextSibling;}
return e;
}
----------------------------------------------------------------------------------------------------------------------------------------------
四, 不正确的隐藏table中的行
想通过隐藏DIV来实现不显示" ;第一行" , 是不行的
<table width="922" border="0" cellspacing="0" cellpadding="0">
<div style="display:none">
<tr>
<td> 第一行</td>
</tr>
</div>
<tr>
<td> 第二行</td>
</tr>
</table>
转自:http://elf8848.javaeye.com/blog/289461