My aim is to update a WordPress post using AJAX. My code so far:
Script:
$.ajax({
type: 'POST',
url: ajax_url,
data: {
'action': 'wp_post',
'ID': post_id,
'post_title': post_title
},
success: function( data ) {
$( '.message' )
.addClass( 'success' )
.html( data );
},
error: function() {
$( '.message' )
.addClass( 'error' )
.html( data );
}
});
PHP:
function wp_post() {
$post['ID'] = $_POST['ID'];
$post['post_title'] = $_POST['post_title'];
$post['post_status'] = 'publish';
$id = wp_update_post( $post, true );
if ( $id == 0 ) {
$error = 'true';
$response = 'This failed';
echo $response;
} else {
$error = 'false';
$response = 'This was successful';
echo $response;
}
}
As you can see the $response
variable in my PHP function is being passed to the success function in my script and the value of $response
is displayed on the page.
I want to modify my success function to do something like this:
success: function( data ) {
if( $error == 'true' ) {
// do something
} else {
// do something else
}
},
The problem is, I am having trouble passing both the $response
and $error
variables in my PHP function to the success function in my scipt.
- Can anyone let me know how to pass
$response
and$error
to my script’s success function? - Is there a better approach I should be taking?
I’m newish to AJAX so forgive me if the question is very basic.
You shoud encode the response of the php script as json, as follows:
And then, in your javascript code:
You can create a
JSON
array like this one, in the backend:And then parse the json array to fetch the returned values, like this:
Wherea you echoed the array from the backend to the frontend, you can’t simply access PHP variables within the JavaScript.
Note that there might be a syntax error, since I’m not testing it.
What you are looking for is
json_encode()
This converts a PHP array to JSON.
For example:
You cannot directly use PHP variables within JavaScript. The best you can do is manipulate PHP output in your JavaScript code.
For example, you could print
$response
as either ‘error’ or ‘no_error’ – and in your AJAX callback, check thatvar data
does not equal ‘error’ (For example).if you use:
on your .php function, remember to use:
on your ajax success.
Example:
And then, in your javascript code:
the javascript variable data contains your echoed $response variable. So using your example, it would be something like this. Be sure you are also asking for html as your return data in the ajax function. here is the docs on that: http://api.jquery.com/jquery.ajax/