我有一个以下的html标记(它是一个让你知道的基本结构,因为有些人会问我<form>
标记在哪里。考虑它在那里。)
<input type="text" name="set_val_1" id="set_val_1" value="1"/>
<input type="text" name="set_val_2" id="set_val_2" value="2"/>
<input type="text" name="max_risk_id" id="max_risk_id" value="5"/>
<input type="submit" value="Enter" name="submit_button"/>
现在,当提交表单时,我想要一个代码来检测是否有任何POST以#34; set_val_
&#34;格式出现。
基于我的问题的算法:
if(isset($_POST['something with the pattern (set_val_)']))
{
$flag = 1;
$val_string = "";
}
if($flag == 1)
{
$max_id = $_POST['max_risk_id'];
for($i = 1; $i<=$max_id; $i++)
{
if(isset($_POST['set_val_'.$i]))
{
$val_string = $val_string. $_POST['set_val_'.$i].",";
}
}
}
如何检查某个帖子是否以特定名称格式发生?
我有多个多选,检查小提琴:
http://jsfiddle.net/p0b4j5o8/24/
因此,我正以这种方式获取多选的数据
if(isset($_POST['max_risk_id']))
{
$max_id = $_POST['max_risk_id'];
for($i = 1; $i<=$max_id; $i++)
{
$offer_combo = '';
if(isset($_POST['risk_mitigator_offer_'.$i]) && isset($_POST['risk_weight_'.$i]))
{
$offer_risk = $_POST['risk_mitigator_offer_'.$i];
$risk_weight = $_POST['risk_weight_'.$i];
print_r($offer_risk);
foreach($offer_risk as $fr)
{
$offer_combo = $offer_combo . $fr . ",";
}
$offer_combo = trim($offer_combo,",");
$mitigator_insert_query = "INSERT INTO mt_risk_mitigator
(camp_id , risk_combination, risk_weight)
VALUES ('".$mysql['camp_id']."','$offer_combo','$risk_weight')";
mysql_query($mitigator_insert_query);
}
}
}
答案 0 :(得分:0)
使用preg_grep和键检查功能
function preg_grep_keys($pattern, $input, $flags = 0) {
return array_intersect_key($input, array_flip(preg_grep($pattern, array_keys($input), $flags)));
}
if(count(preg_grep_keys('/set_val_\d+/', $_POST)) > 0)
{
$flag = 1;
$val_string = "";
}