亲爱的stackoverflow成员,
我已经在Drupal中建立了一个网站,我正在尝试通过构建一个用户点系统来创建一种有趣的方式让网站成员参与该网站,系统已经到位,但我正在尝试建立一个商店他们可以买“头衔”。
这是我为商店写的脚本,有一些错误处理,但我遇到了问题,
在我的javascript中,我有2个变量的函数buyitem(),我想在我的PHP函数中使用哪个检查我的数据库中的所有内容,有没有办法将这些变量从javascript转换为php函数我写的没有去外部PHP文件?
提前谢谢, 乔纳森<?php
include "php-scripts/DBConnection.php";
$con = getconnection();
mysql_select_db("brokendi_BD", $con);
function getKarma()
{
$result = mysql_query("SELECT * FROM userpoints WHERE uid='getUID()'");
$row = mysql_fetch_array($result);
$currentkarma = (int)$row['points'];
return $currentkarma;
}
function getUID()
{
global $user;
if ($user->uid)
{
$userID=$user->uid;
return $userID;
}
else
{
header('Location: http://brokendiamond.org/?q=node/40');
}
}
function hasRole($roleID)
{
$usersid = getUID();
$returnValue = false;
$result = mysql_query("SELECT * FROM users_roles");
while ($row = mysql_fetch_array($result))
{
if ($row['uid'] == $usersid)
{
if ($row['rid'] == $roleID)
{
$returnValue = true;
break;
}
}
}
return $returnValue;
}
function enoughKarma()
{
if ( getKarma() >= $requiredKarma)
{
return true;
}
else
{
return false;
}
}
function buyRole()
{
$currentKarma = getKarma();
$newkarma = $currentKarma - $requiredKarma;
$userID = getUID();
mysql_query("UPDATE userpoints SET points = '$newkarma' WHERE uid='$userID'");
mysql_query("INSERT INTO users_roles (uid, rid) VALUES ($userID, $roleID)");
}
?>
<script type="text/javascript">
buyItem(1 , 0);
function SetStore()
{
}
Function buyItem(itemID,reqKarma)
{
if (<?php enoughKarma(); ?>)
{
<?php buyRole(); ?>
}
else
{
alert('You do not have enough Karma to buy this title.');
}
}
</script>
答案 0 :(得分:4)
PHP是服务器端脚本,javascript是客户端,服务器端脚本在页面加载之前执行,这意味着你的javascript无法将变量传递给它,但是你可以将php变量传递给你的js。
在你的情况下,最好的解决方案是使用ajax将这些变量发送到php并在其上设置php设置变量,这并不能完全解决你的问题,但是在你的代码中有一些创造力你可以实现它。
答案 1 :(得分:1)
你可以重新加载页面(我怀疑你在寻找什么)或者发送一个ajax调用你的PHP脚本发送2个变量。
如果您使用的是jQuery,this应该会告诉您如何执行此操作