0

嗨,以下所有功能都可以正常工作,并且完全按照我的意愿工作,但我希望这是一个 .post 而不是 .get 任何人都可以看到以下问题吗?它几乎直接来自堆栈溢出的另一个答案,应该可以正常工作。

jQuery(document).ready(function() {
        //This function adds a development.
        jQuery('#add_dev').bind('submit', function(e) {
        e.preventDefault();
        var data = {
            action: 'AjaxAddDev',
            security: AjaxHandler.ajaxnonce,
            name: jQuery('#dev_name').val(),
            desc: jQuery('#dev_desc').val()
        };        
        //alert(data['name']+data['desc']);
        jQuery.get(
                AjaxHandler.ajaxurl,
                data,
                function(response) {
                    // ERROR HANDLING
                    if (!response.success) {
                        // No data came back, maybe a security error
                        if (!response.data) {
                            //$('#my-answer').html('AJAX ERROR: no response');
                            alert("Problem adding Development");
                        } else {
                            //$('#my-answer').html(response.data.error);
                            alert(response.data);
                        }
                    } else {
                        //$('#my-answer').html(response.data);
                        alert("Problem adding Development");
                    }
                }
        );
    });
});

将其设置为 .post 时出现的错误是:

l.send(n.hasContent && n.data || null), r = function (e, i) {

这是 jquery 的未缩小版本的第 2963 行

/*! jQuery v1.10.2 | (c) 2005, 2013 jQuery Foundation, Inc. | jquery.org/license */ 

谁能指出我正确的方向?

更新代码:

jQuery(document).ready(function() {
        //This function adds a development.
        jQuery('#add_dev').bind('submit', function(e) {
        e.preventDefault();
        var data = {
            action: 'AjaxAddDev',
            security: AjaxHandler.ajaxnonce,
            name: jQuery('#dev_name').val(),
            desc: jQuery('#dev_desc').val()
        };        
        //alert(data['name']+data['desc']);
        jQuery.ajax({
            url: AjaxHandler.ajaxurl,
            type: "POST",
            data: data,
            success:function(data) {
            // This outputs the result of the ajax request
                alert(data);
            },
            error: function(errorThrown){
                alert(errorThrown['error']);
            }
        });
    });
});

我正在使用firefox最新版本,

我将以下内容作为 errotThrowen['error'] 返回

function () {
                if (l) {
                    var t = l.length;
                    (function i(t) {
                        x.each(t, function (t, n) {
                            var r = x.type(n);
                            "function" === r ? e.unique && p.has(n) || l.push(n) : n && n.length && "string" !== r && i(n)
                        })
                    })(arguments), n ? o = l.length : r && (s = t, c(r))
                }
                return this
            }
4

2 回答 2

0

如果你想改变 ajax

$("#yourid").change(function () {            
        var p = {
            postfieldname: value,
            postfieldname: value,
            postfieldname: value,
            postfieldname: value,
            postfieldname: value,
            postfieldname: value,
            postfieldname: value,
             }
        $.ajax({
            url: "library/test.php",
            type: "POST",
            data: p,
            success: function (e) {
                var t = jQuery.parseJSON(e);
                $("#id").val(t['a']);
            }
        })
    })

在 test.php 上

$array = array("a" => "test", "b" => "array");
$encode = json_encode($aray);
echo $encode;
于 2013-11-04T15:42:56.907 回答
0

好吧,这有点奇怪,

为了让它工作,我只需添加以下内容作为帖子 URL。

url: AjaxHandler.ajaxurl+"&security="+AjaxHandler.ajaxnonce,

如果我将安全性排除在 url 之外,它会失败,我不知道为什么,但这让我在圈子里转了几个小时。

于 2013-11-04T17:10:55.693 回答