在我的外部JavaScript文件中,我有以下jQuery代码:
$(function(){
$('#follow').on('click',function(){
$.ajax({
type: 'POST',
url : 'functions/follow.php',
data: {follower : session_id,
user : p_id,
success: function(result) {
if(result == 'followed'){
$('#follow').attr('id','unfollow').text('-Unfollow');
}
}
});
});
});
在我的正常页面,我有这个:
var session_id = '<?php echo $_SESSION['id']; ?>',
p_id = '<?php echo $p_id; ?>';
,但这并没有将变量传递给jQuery函数。在调用JavaScript文件之前,我也设置了这两个变量。
EDIT:我已经在按钮所在的同一页面上用函数测试了这一点,并且我用echo传递了PHP值,然后它工作了。
您可以在jquery对象中创建一个命名空间,甚至允许在事件中访问它。像这样:
$.mynamespace = {
session_id: '<?php echo $_SESSION['id']; ?>',
p_id: '<?php echo $p_id; ?>'
};
然后在代码中引用这些名称空间变量,如下所示:
$(function(){
$('#follow').on('click',function(){
$.ajax({
type: 'POST',
url : 'functions/follow.php',
data: {follower : $.mynamespace.session_id,
user : $.mynamespace.p_id,
success: function(result) {
if(result == 'followed'){
$('#follow').attr('id','unfollow').text('-Unfollow');
}
}
});
});
});
这也将使它们可用于任何其他jQuery事件/回调等
(注意:确保你的变量在你尝试使用它们之前被设置,即在脚本中更高)