2016-03-17 32 views
0

我以前曾帮助here为某些复选框制作通用的Ajax函数。我现在正试图将该项目整合到一个Wordpress网站,并有几个问题。在wordpress中失败的ajax调用

这里是我当前的代码:

<label class="rep_label"><input type="checkbox" id="goal1<?php get_current_user_id() ?>" name="GOAL_1_HIT" value="1" <?php if($rep_goal1_hit == 'YES'){echo "checked";}?> /> 
      <?php echo $rep_goal1; ?></label> 
<br />   
<label class="rep_label"><input type="checkbox" id="goal2<?php echo get_current_user_id() ?>" name="GOAL_2_HIT" value="1" <?php if($rep_goal2_hit == 'YES'){echo "checked";}?> /> 
      <?php echo $rep_goal2; ?></label> 
<br />   
<label class="rep_label"><input type="checkbox" id="goal3<?php echo get_current_user_id() ?>" name="GOAL_3_HIT" value="1" <?php if($rep_goal3_hit == 'YES'){echo "checked";}?> /> 
      <?php echo $rep_goal3; ?></label> 
<br />   
<label class="rep_label"><input type="checkbox" id="incentive<?php echo get_current_user_id() ?>" name="INCENTIVE_HIT" value="1" <?php if($rep_incentive_hit == 'YES'){echo "checked";}?> /> 
      <?php echo $rep_incentive; ?></label> 

JS/AJAX

jQuery(document).ready(function($) { 
    $("input[type=checkbox]").change(function() { 
     var $input = $(this); 
     $.ajax({ 
      url: 'checkbox.php', 
      type: 'POST', 
      data: { db_column:$input.attr("name"), strState:$input.is(":checked"), user:"<?php echo $current_user->ID; ?>" }, 
      success: function() { // this happens after we get results 
       $input.attr('checked', true);    
      }, 
      error:function(){ 
       $input.attr('checked', false); 
      } 
     }); 
    }); 
}); 

PHP

<?php 

$db_column = $_POST['db_column']; 
$strState = $_POST['strState']; 
$user = $_POST['user']; 

if(set_cimyFieldValue('$user', '$db_column', '$strState')){ 
    echo "ok"; 
} else { 
    echo "error"; 
} 

?> 

我收到错误在我的javascript “输入意外结束” 即我已无休止地搜索了无济于事。

我已经在html中的脚本和Ajax调用甚至没有被触发,所以我把它移动到一个.js文件,并将它包含在同一个地方,现在ajax调用,但返回404 PHP文件。

这只是我必须实施的Ajax冰山一角。我需要知道在Wordpress中使用我自己的Ajax函数时需要考虑的一般问题?

如果有人熟悉Cimy额外用户字段,我只是试图为该插件提供的字段创建一个ajax驱动的前端。我想我有问题试图在我的php文件中使用插件功能...

+0

经过更多的挖掘,我意识到我真正寻找的只是ajax调用php函数的一般用法。考虑到我使用的插件,我认为上面所做的很多事情都是过度的。 –

回答

-1
data: ({ db_column:$input.attr("name"), strState:$input.is(":checked"), user:"<?php echo $current_user->ID; ?>" })