当前位置: 首页 > 知识库问答 >
问题:

超文本标记语言表单提交一个输入字段返回:未捕获的类型错误:将圆形结构转换为JSON

岳城
2023-03-14

无法找出导致未捕获TypeError的原因:将循环结构转换为JSON。我有表格(1个输入字段和提交按钮)

<form id="contact-form" method="post" action="submit_form.php" role="form" target="hiddenFrame">
<div class="controls">
    <div class="row">
        <div class="col-md-6">
            <div class="form-group">
                <label for="form_name">Author *</label>
                <input id="form_name" type="text" name="Author" class="form-control" placeholder="Enter name *" required="required" data-error="name is required.">
                <div class="help-block with-errors"></div>
            </div>
        </div>
    </div>
</div>
</div>
<div class="col-md-12 text-center">
    <input type="submit" class="btn btn-success btn-send" name="submit">
</div>
</div>
</div>
</form>
<script src="./js/submit_frm.js"></script>

提交_frm.js代码:

$(function () {

// init the validator
// validator files are included in the download package
// otherwise download from http://1000hz.github.io/bootstrap-validator

$('#contact-form').validator();


// when the form is submitted
$('#contact-form').on('submit', function (e) {

    // if the validator does not prevent form submit
    if (!e.isDefaultPrevented()) {
        var url = "submit_frm.php";

        // POST values in the background the the script URL
        var data = JSON.stringify(e);
        $.ajax({
            type: "POST",
            url: url,
            data: data,
            success: function (data)
            {
                // data = JSON object that contact.php returns

                // we recieve the type of the message: success x danger and apply it to the 
                var messageAlert = 'alert-' + data.type;
                var messageText = data.message;

                // let's compose Bootstrap alert box HTML
                var alertBox = '<div class="alert ' + messageAlert + ' alert-dismissable"><button type="button" class="close" data-dismiss="alert" aria-hidden="true">&times;</button>' + messageText + '</div>';

                // If we have messageAlert and messageText
                if (messageAlert && messageText) {
                    // inject the alert to .messages div in our form
                    $('#contact-form').find('.messages').html(alertBox);
                    // empty the form
                    $('#contact-form')[0].reset();
                }
            }
        });
        return false;
    }
})
});

google chrome控制台显示,错误源于js文件中的var data=JSON. stringify(e);行。我将感谢任何帮助解决这个错误。

共有2个答案

谭修然
2023-03-14

您不能将circler对象(例如DOM元素)转换为JSON,并且e引用了提交的表单,因此您不能仅将事件转换为JSON

如果希望以JSON的形式获取表单数据,可以从表单中创建FormData对象,然后对其进行迭代并手动将其转换为JSON,如下所示:

$('#contact-form').on('submit', function (e) {
    var formData = new FormData(e.target);
    var object = {};
    formData.forEach(function(value, key){
        object[key] = value;
    });
    var json = JSON.stringify(object);
    // do something with json ...
}
颜永怡
2023-03-14

这是无效的:var data=JSON.stringify(e)

事件中的e通常是对该事件的引用,而不是您的数据。相反,您应该执行以下操作:

e.preventDefault();

var data = $(this).serialize();

 类似资料:
  • 我在这里收到以下错误 TypeError:将循环结构转换为JSON-- 问题似乎是圆形结构不能使用JSON stringify转换。然而,我似乎找不到我使用圆形结构的地方。我是不是漏了什么? 示例循环结构:var a={};a、 b=a; 取东西 新信息 编辑-完全错误

  • 我有一个带JSON.stringify的tableDnD拖放: 我收到以下错误消息: 未捕获的类型错误:将圆形结构转换为JSON 我只有Chrome问题。

  • 我有下面的XPATH,它使用了兄弟轴之后的轴 是否可以将其转换为CSS?CSS比XPATH快。如果我可以将其转换为CSS用于Selenium测试,那就太好了。 XPATH:<代码>//表[@id=“data\u configuration\u edit\u data\u object\u tab\u details\u tb\u fields”]//td/div/input[@value=“ARE

  • 问题内容: 我有以下… 该调用以下。 但是,我的代码永远不会到达“ ZOMG HERE”,而是在运行时抛出以下错误 有谁知道是什么原因造成的? 问题答案: 这意味着您在请求中传递的对象(我想是)具有循环引用,例如: 无法转换这样的结构。 注意 :DOM节点就是这种情况,即使没有将它们附加到DOM树,它们也具有循环引用。在大多数情况下 ,每个节点都有一个。具有通过至少一个参考DOM树和指回再次,这是

  • 我之所以发布这个问题,是因为许多开发人员或多或少地以不同的形式问同一个问题。我会自己回答这个问题(我是iText Group的创始人/首席技术官),这样它就可以成为“维基答案”如果堆栈溢出的“文档”特性仍然存在,那么这将是文档主题的一个很好的候选者。 我正在尝试将以下HTML文件转换为PDF: 在浏览器中,这种超文本标记语言如下所示: HTMLWorker根本不考虑CSS 当我使用时,我需要创建一

  • 我在输入上使用typeahead发送建议。。一切都很好,但我知道我想动态创建HTML表并在表中赋值,所以在我的java脚本中,我声明HTML变量来存储表,然后在返回值时使用这个变量。当我将html保存在变量中时,问题就出现了,它开始给出错误,即变量未定义,当我将它放在引号中时,返回时,它只显示变量。。我不知道该怎么做,也不知道应该使用哪种方法,但我被困在了这一点上,我的HTML正在工作 这里是我的