簡體   English   中英

Wordpress / Jquery Ajax,獲取工作后發布失敗並出現jquery錯誤

[英]Wordpress / Jquery ajax, get works post fails with jquery error

大家好,以下所有功能都可以正常運行,並且完全按照我的意願運行,但是我希望這是一個.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
            }

如果你想改變就阿賈克斯

$("#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;

好吧,這有點奇怪

為了使其正常工作,我只需要添加以下內容作為發布網址。

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

如果我將安全性遺漏在url中,它將失敗,我不知道為什么,但這使我繞了幾個小時。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM