我有一个页面可以为请求访问网站的用户生成邀请密钥。
<section id="beta">
<span class="title">Users Requesting an Invite</span>
<div>
<ul>
<li>#</li>
<li>Email</li>
<li>Invite Code</li>
<li></li>
</ul>
</br>
<ul>
<?
$i = 1;
while($request = mysql_fetch_array($reqlist)) {
?>
<span>
<li><?=$i?></li>
<li><?=$request['email']?></li>
<?php if(isset($request['invite_code']) && !empty($request['invite_code'])) {?>
<li><?=$request['invite_code'];?></li>
<?} elseif(empty($request['invite_code'])) {?>
<li><?if($onum == $i){echo $invcode;}?></li>
<li>
<form id="<?=$i?>" method="post">
<input type="submit" name="submit" value="Generate" />
<input type="hidden" name="num" value="<?=$i?>"/>
</form>
</li>
<?php if($onum == $i && isset($invcode) && !empty($invcode)) {?>
<li>
<form method="post" name="save">
<input type="submit" name="save" value="Save" />
<input type="hidden" name="inv" value="<?=$invcode?>" />
<input type="hidden" name="req_id" value="<?=$request['id']?>" />
</form>
</li>
<? } ?>
<? } ?>
</br>
</span>
<?
$i++;
//$invcode = '';
}
?>
</ul>
</div>
</section>
因为我的代码声明该过程如下。该表打印出所有请求邀请的用户,最后使用生成按钮。单击生成后,我有一个函数可以创建一个带有键的变量。生成密钥后,弹出窗体保存的新<li>
,以便将其保存在数据库中。
但问题是当点击生成时它只适用于第一条记录。我理解它归因于$invcode = '';
使其成为NULL
,但我不确定如何以不同方式执行此操作,因此如果点击任何生成按钮,它将仅适用于特定的人。
更新:已更新工作回答。也好像我说错了这个问题。只有第一行会一次生成代码。每个行的保存工作完全正常。它只是每个生成按钮只能在第一行工作,如果没有设置$ invcode。但我通过在混合中添加行号来修复它。
答案 0 :(得分:0)
感谢批评,我们将研究新的编码方式,因为有些项目已被弃用。但无论如何都想出了如何修复它。
我在生成表单中添加了<input type="hidden" name="num" value="<?=$i?>"/>
并让它检查邮政编号是否等于行号,如果它与回声相匹配。 if($onum == $i){echo $invcode;}
答案 1 :(得分:0)
尝试使用 -
<input type="submit" name="save[]" value="Save" />
<input type="hidden" name="inv[]" value="<?=$invcode?>" />
<input type="hidden" name="req_id[]" />
由于输入类型名称相同,您获得第一行的值。你需要在name之后使用[]来获取该名称中的所有值
您可能需要更改提交值的代码。在提交页面print_r
变量上查看。
示例 -
print_r($_POST['inv']);
它将输出一个数组,我希望你可以独自完成其他事情:)