ie6中form.submit()不能正常提交的解决方法

本文介绍了在IE6浏览器中使用JavaScript提交表单时遇到的问题及两种解决方案。一种是移除a标签的href属性并通过CSS模拟按钮样式;另一种是在a标签中设置href为javascript:void(0)并返回false阻止默认行为。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

IE6下用 "提交"  按钮,可以正常提交数据,但通过js脚本:formElement.submit(),提交却失败。本文为大家提供二种解决方法,有需要的朋友可以看看。


有人说用setTimeout()的办法来解决;

进一步研究发现,<a/>有个链接属性 href,而form也有一个页面请求属性 action,当两属性同时存在时,点击<a/>当然会优先<a/>的href链接,但如果是 <a href="javascript:;" ></a>,又会是什么情况呢?
实践证明IE7.0+ , FF3.0+, Opera9.6+ 均能正确处理, 忽略<a/>的href, 执行表单的submit动作, 唯有 IE6 仍坚持着自己的原则, 只要有 href , 就只尝试执行链接 href , 除非你的<a/>标签中去掉 href属性, 但去掉 href 你将发现IE 下将不会出现下划线;
分析是由于 ie6 执行默认动作引发的问题。

为大家介绍二种解决方法,供参考:
方法1,


<a class="bt_3"  style="cursor:pointer;" id="btnSubmit1" onclick="submitPage()">提交</a>

这种方法根本没有href属性,用style="cursor:pointer;" 产生手型图标来模拟。

方法2,


<a class="bt_3"   href="javascript:void(0)"  id="btnSubmit1" onclick="submitPage();return false;">提交</a>

onclick 返回 false ,阻止浏览器的默认行为。也可以达到相同的目的。

就是这些了,希望以上的方法可以解决大家的问题。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值