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文件中使用插件功能...
经过更多的挖掘,我意识到我真正寻找的只是ajax调用php函数的一般用法。考虑到我使用的插件,我认为上面所做的很多事情都是过度的。 –