使用ajax时停止页面重新加载

时间:2015-03-12 11:13:57

标签: ajax wordpress

我已经创建了一个wordpress插件,可以使用ajax对帖子进行投票。 当您点击'投票'链接jquery弹出窗口工程,你的投票被添加但页面重新加载

    add_action("wp_ajax_my_user_vote", "my_user_vote");
    add_action("wp_ajax_nopriv_my_user_vote", "my_must_login");

    function my_user_vote() {

    if ( !wp_verify_nonce( $_REQUEST['nonce'], "my_user_vote_nonce")) {
        exit("No naughty business please");
    }   


    $user_id = get_current_user_id();

    date_default_timezone_set('GMT+2');
    $dateVoted = get_user_meta($user_id, 'date');
    $today = date('d M Y');
    if ($dateVoted === $today){
        //Already Voted
        echo '<script language="javascript">';
        echo 'alert("already voted")';
        /*
        echo 'alert("User ID: ' . $user_id . '")';
        echo 'alert("Date Voted: ' . $dateVoted . '")';
        echo 'alert("Today: ' . $today . '")';
        */ 
        echo '</script>';

    }else{

       $vote_count = get_post_meta($_REQUEST["post_id"], "votes", true);
       $vote_count = ($vote_count == '') ? 0 : $vote_count;
       $new_vote_count = $vote_count + 1;

       $vote = update_post_meta($_REQUEST["post_id"], "votes", $new_vote_count);

       if($vote === false) {
          $result['type'] = "error";
          $result['vote_count'] = $vote_count;
       }
       else {
          $result['type'] = "success";
          $result['vote_count'] = $new_vote_count;
       }

       if(!empty($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest') {
          $result = json_encode($result);
          echo $result;
       }
       else {
          header("Location: ".$_SERVER["HTTP_REFERER"]);
       }

       update_user_meta( $user_id, 'date', $today );

    }
    die();

}


function my_must_login() {
   echo "You must log in to vote";
   die();
    }

    add_action( 'init', 'my_script_enqueuer' );

    function my_script_enqueuer() {
       wp_register_script( "my_voter_script", WP_PLUGIN_URL.'/video-of-the-     day/my_voter_script.js', array('jquery') );
       wp_localize_script( 'my_voter_script', 'myAjax', array( 'ajaxurl' => admin_url( 'admin-ajax.php' )));        

        wp_enqueue_script( 'jquery' );
       wp_enqueue_script( 'my_voter_script' );

    }

我还有一个jquery文件:

 jQuery(document).ready( function() {

       jQuery(".user_vote").click( function() {
          post_id = jQuery(this).attr("data-post_id")
          nonce = jQuery(this).attr("data-nonce")

      jQuery.ajax({
         type : "post",
         dataType : "json",
         url : myAjax.ajaxurl,
         data : {action: "my_user_vote", post_id : post_id, nonce: nonce},
         success: function(response) {
            if(response.type == "success") {

            }
            else {
               alert("Your vote could not be added")
            }
         }
      });   

   })

    });

为什么ajax无法正常工作?

1 个答案:

答案 0 :(得分:1)

试试这个

jQuery(".user_vote").click( function(e) {
  e.PreventDefault();
});