I am trying to send a value to my wordpress database (wp_usermeta table) when a button is clicked.
Here is what I know so far, I know I need to post the value using AJAX, I also know that wordpress has a function for updating the wp_usermeta table, that is:
update_user_meta( $user_id, 'dashboard_onboarding_status', 'myValue' );
The good news is that myValue isn’t a variable – I just want to send the word “complete” to the db. It’s also an admin side script – I’m not sure if that makes a difference on how to call the ajax url.
Here is what I have codewise:
In my main js file, I have the following AJAX script:
$('.skizzar_onabording_dashboard #next.step5').click(ajaxSubmit);
function ajaxSubmit(){
jQuery.ajax({
type:"POST",
url: "/wp-admin/admin-ajax.php",
data: {
"value" : "completed"
},
success:function(data){
console.log(data);
}
});
return false;
}
So when a user clicks on .skizzar_onabording_dashboard #next.step5
that should trigger the AJAX function.
Then in my main plugin php file I have the following:
function myFunction(){
global $wpdb;
$user_id = get_current_user_id();
$completed = $_POST['value'];
update_user_meta( $user_id, 'onboarding_status', $completed );
die();
}
add_action('wp_ajax_myFunction', 'myFunction');
I think needless to say this doesn’t work, but I’m very new to using AJAX and I ca’t figure out why. Seems like it should be simple though – essentially I just want to press a button and add “completed” to the key “onboarding_status” in the usermeta table.
Almost all you need is located here.
First you’ll need to localize your
admin-ajax.php
, beause calling it likeurl: "/wp-admin/admin-ajax.php"
is not a good practice.Then your ajax script to call:
And finally the ajax in your js file
This should be it.
DISCLAIMER
I’m never 100% sure if it’s
or
But try it and see which one will give you your function callback. I’m pretty sure it should be the first one.
Also you can check the return of the ajax call in your inspector. Just go to ‘Network’ tab and select XHR and you should see
admin-ajax.php
and when you click on it you can see all the relevant data it sends (headers, response etc.).add your ajax function as the action