7

我试图弄清楚为什么这个 JavaScript 不会阻止表单被提交:

<form action="http://www.example.com" id="form">
    <input type="text" />
    <input type="submit" />
</form>

<script>
var code = function () {
    return false;
};
var element = window.document.getElementById("form");
if (element.addEventListener) {
    element.addEventListener("submit", code, false);
}
</script>

除非我将以下 onsubmit 属性添加到表单元素:

<form action="http://www.example.com" id="form" onsubmit="return false">
    <input type="text" />
    <input type="submit" />
</form>

<script>
var code = function () {
    return false;
};
var element = window.document.getElementById("form");
if (element.addEventListener) {
    element.addEventListener("submit", code, false);
}
</script>

似乎单独的 addEventListener 方法应该可以解决问题。有什么想法吗?我在 Mac 上,在 Safari、Firefox 和 Opera 上遇到相同的结果。谢谢。

4

3 回答 3

8

将两个非常有用的答案中的信息组合成一个适用于 Mac 和 PC 的解决方案:

<script>
var code = function (eventObject) {
    if (eventObject.preventDefault) {
        eventObject.preventDefault();
    } else if (window.event) /* for ie */ {
        window.event.returnValue = false;
    }
    return true;
};
var element = window.document.getElementById("form");
if (element.addEventListener) {
    element.addEventListener("submit", code, false);
} else if (element.attachEvent) {
    element.attachEvent("onsubmit", code);
}
</script>
于 2009-11-30T15:34:30.097 回答
6

看起来如果您将功能更改为

var code = function(e) {
    e.preventDefault();
}

它应该做你正在寻找的东西。

资源

于 2009-06-08T23:20:42.850 回答
2

我认为您正在寻找的是实现它的浏览器preventDefault()的接口方法。Event它将以您期望的“ return false”方式取消表单提交。

更多herehere

<script type="text/javascript">
 var code = function (evt) {
            if (evt.preventDefault) {
                evt.preventDefault();
            }
            return false;
};
window.onload = function() {
    var element = window.document.getElementById("form");
    if (element.addEventListener) {
        element.addEventListener("submit", code, false);
    }
};
</script>
于 2009-06-08T23:34:35.553 回答