我正在使用一个非常基本的随机名称生成器。生成器工作得很好,并通过HTML表单提交按钮调用。现在,在用户想要保存名称的情况下,我将有第二个按钮,它将调用PHP邮件操作向该名称发送电子邮件。在添加邮件功能之前,我只是试图将变量存储在某个地方,以便我可以提醒它并验证是否可以控制它。在以下代码中,$ field2是由$ id_num定位的名称,它等于$ search_str。然后我尝试和分配$ FIELD2全局变量$ nameContainer:为PHP全局变量赋值以提醒
<body>
<?
$nameContainer = "Mary";
?>
<?
function loadName() {
global $nameContainer;
if(!empty($_POST['act'])) {
$lineNum = rand(1, 5189);
$search_str = $lineNum;
$lines = file('names_girls_5189_origin.csv');
foreach($lines as $line){
list($id_num, $field2, $field3, $field4)=explode(",",$line);
$nameContainer = ($id_num == $search_str) ? "$field2" : "";
echo ($id_num == $search_str) ?
"<table style= 'height: 100%;'>
<tr style='width: 100%; height= '200px';'>
</tr>
<center><span class='myText' style='color: white; font-size: 48px;'>$field2</span>
<span style='color: #E8C8D5; font-size: 36px'>Smith</span><br/>
<span class='myText' style='color: #2E7B4D; font-size: 24px;'>Origin: $field3</span><br/>
<span class='myText' style='color: #2E7B4D; font-size: 24px;'>Meaning: $field4</span></center>
</table>" : "";
}
}
}
loadName();
?>
<script type="text/javascript">
function alertName() {
alert("<? getName(); ?>");
}
</script>
<?
function getName() {
global $nameContainer;
echo $nameContainer;
}
?>
<center><form action="index.php" method="post">
<input type="hidden" name="act" value="run" />
<p><input type="submit" value="New" /></p>
</form>
</center>
<center><button onclick="alertName()">Alert</button></center>
</body>
看来我的问题从$ nameContainer =($ ID_NUM == $ SEARCH_STR)茎? “$ field2”:“”;因为$ nameContainer = $ field2;工作,但分配在csv最后的名字,而不是匹配搜索字符串。我意识到这里可能存在一些基本的逻辑,所以任何帮助都是值得赞赏的!
更新(样本CSV):
ID,Name,Origin,Meaning
1,Aaliyah,"Arabic, Hebrew","high exalted, to ascend"
2,Akala,Aboriginal,A parrot.
3,Alba,Aboriginal,A sand hill. Also see Albina.
5188,Zelma,,A divine helmet. From the name Anselma. Also see Salima.
5189,Zola,,Life.`
右:'回声 “ID_NUM:” $ ID_NUM “SEARCH_STR:”。$ SEARCH_STR;'另外,为什么是$ field2在该行上的引号? – mkaatman 2013-03-05 01:08:43
你确定每一行的第一个数据是一个数字,并且这些数字填充了区间[1,5189]? – 2013-03-05 01:16:57
@Lewyx是的,我自己编译了csv。第一列填入ID号码,后面跟着更新的OP,名称,来源和含义。数字从1开始排除第一行。 – JTEngland 2013-03-05 03:25:59