我已经在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>
PHP是服务器端脚本,javascript是客户端脚本,服务器端脚本在页面加载之前执行,这意味着你的javascript无法将变量传递给它,但你可以将PHP变量传递给你的js。
在您的情况下,最好的解决方案是使用ajax将这些变量发送到php,并让php设置变量,这并不能完全解决您的问题,但只要代码中有一些创造性,您就可以实现这一点。
您可以重新加载页面(我怀疑这是您想要的),也可以对php脚本进行ajax调用,发送2个变量
如果您使用的是jQuery,这应该会让您了解如何进行