jQuery POST不使用IE 11提交表单值

use*_*190 8 jquery internet-explorer-11

我已经尝试了几个小时找到这个问题的解决方案,但以下代码根本不适用于Internet Explorer 11.它适用于Chrome和Firefox.使用IE11时,帖子已提交,但提交的表格为空.

<!DOCTYPE html>
    <html>
        <head>
            <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
            <script src="http://code.jquery.com/jquery-latest.js" type="text/javascript"></script>
        </head>
        <body>
            <form action="/Mandate/Edit" id="mandateForm" method="post">            
                <input id="ExternalId" name="ExternalId" type="hidden" value="" />
                <input id="mandateName" name="mandateName" type="text" />
                <a href="#" id="md-submit">Create</a>
            </form>
            <script type="text/javascript">
                $(function () {
                    $("#md-submit").on("click", function (e) {
                        e.preventDefault();
                        var form = $("#mandateForm");
                        var request = $.ajax({
                            type: "POST",
                            url: form.attr("action"),
                            data: {
                                mandateName: "test4711"
                            },
                            dataType: 'json',
                            cache: false
                        });
                    });
                });
            </script>
        </body>
    </html>
Run Code Online (Sandbox Code Playgroud)

非常感谢您的帮助.

Mar*_*mit 0

jquery 中 ie 中的表单序列化似乎存在一些问题。我通常使用这个插件:http://jquery.malsup.com/form/#api

这似乎是解决问题的最简单的方法。但这远不是最干净的方式。您可以尝试的另一件事是:让服务器监听 json requestdata 。并将其序列化为 json 字符串。或者自己制作一个序列化函数。这就像 3 行代码。