我正在添加一个在单击按钮时应该调用的函数,我有一个带有以下 jquery 代码和 ajax 调用的 js 文件:
jQuery(document).ready( function() {
function getUrlParameter(sParam){
var sPageURL = window.location.search.substring(1);
var sURLVariables = sPageURL.split('&');
for (var i = 0; i < sURLVariables.length; i++) {
var sParameterName = sURLVariables[i].split('=');
if (sParameterName[0] == sParam) {
return sParameterName[1];
}
}
}
jQuery('#upload_btn').click( function(e) {
e.preventDefault();
var flag = true;
var postId = getUrlParameter('preview_id');
var files = jQuery('#file_tool').prop('files');
console.log(files);
var dataS = {
'action': 'upload_button',
'preview_id': postId,
'files': files,
'set': flag
}
jQuery.ajax({
type : 'post',
url : diario.upload,
processData: false,
contentType: false,
data : dataS,
success: function(response) {
if(response.type == "success") {
console.log('jquery works');
} else console.log(response);
}
});
});
});
当我单击按钮时,console.log 显示文件 obj,因此至少 onClick 有效,但之后它显示jquery.js:4 POST custom/wp-admin/admin-ajax.php 400。这就是我的functions.php的样子:
add_action( 'wp_enqueue_scripts', 'enqueue_onClick_upload' );
//custom_js_enqueuer
function enqueue_onClick_upload() {
wp_register_script( 'onClick_upload', WP_CONTENT_URL.'/themes/microjobengine/onClick_upload.js', array('jquery') );
wp_localize_script( 'onClick_upload', 'diario', array( 'upload' => admin_url( 'admin-ajax.php' )));
wp_enqueue_script( 'jquery' );
wp_enqueue_script( 'onClick_upload' );
}
add_action('wp_ajax_upload_button', 'upload_button');
add_action('wp_ajax_nopriv_upload_button', 'upload_button');
// upload button function
function upload_button() {
$postID = $_POST['preview_id'];
if ($_POST['set']) {
if($_POST['files']['size'] === 0 )
echo "<script>console.log('There's no images.');</script>";
}
$result['type'] = 'success';
echo json_encode($result);
wp_die();
}
我不知道为什么它找不到动作,一切都按照wp所说的那样完成,我希望有人能帮忙,谢谢。
- 编辑 -
好的,所以现在我尝试只通过'action': 'upload_button'
,错误没有出现,但响应没有成功,我这样做了,我的函数中的所有代码都注释了,只留下 las 3 行,以便返回成功,但是它没有,所以它可能会找到该功能,但由于某种原因它没有被执行,当然这意味着当我传递额外的数据时会发生错误,关于为什么会发生这种情况的任何想法?