嗨,以下所有功能都可以正常工作并完全按照我的意愿执行,但我希望这是一个 .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']);
}
});
});
});
我正在使用火狐最新版本,
我得到以下返回为 errotThrowen['错误']
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
}
如果你想在更改时 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']);
}
})
})
并在测试中.php
$array = array("a" => "test", "b" => "array");
$encode = json_encode($aray);
echo $encode;
好吧,这有点奇怪,
为了使它正常工作,我只需添加以下内容作为帖子URL。
url: AjaxHandler.ajaxurl+"&security="+AjaxHandler.ajaxnonce,
如果我将安全性排除在 url 之外,它就会失败,我不知道为什么,但这让我绕了几个小时。