[英]Find checkbox values from Dynamically generated Divs in php using javascript
[英]how read dynamically generated checkbox values
遵循通過PHP while循環動態生成的復選框結構,因此所有checkbox name="cols[]"
復選框名稱均相同
<li>
<input type="checkbox" name="tab" value="table1"/>
<ul>
<li><input type="checkbox" name="cols[]" value="t1col1"</li>
<li><input type="checkbox" name="cols[]" value="t1col2"</li>
<li><input type="checkbox" name="cols[]" value="t1col3"</li>
</ul>
</li>
<li>
<input type="checkbox" name="tab" value="table2"/>
<ul>
<li><input type="checkbox" name="cols[]" value="t2col1"</li>
<li><input type="checkbox" name="cols[]" value="t2col2"</li>
<li><input type="checkbox" name="cols[]" value="t2col3"</li>
</ul>
</li>
問題是當我在php中讀取波紋管的值時,無法根據其父類別區分數組cols[]
的值。 這種情況下的解決方案是什么
if(isset($_POST['tab']))
{
foreach($_POST['tab'] as $tabs_entry)
{
$query.=$tabs_entry.'~';
if(isset($_POST['cols']))
{
foreach($_POST['cols'] as $cols_entry)
$query.$cols_entry.',';
$query.="-";
}
}
}
echo $query;
通過對表和復選框使用相同的復選框名稱數組來解決,並且可以通過添加分隔符“〜”(代字號)和“,”(逗號)來拆分父值和子值
<li>
<input type="checkbox" name="tab[]" value="table1~"/>
<ul>
<li><input type="checkbox" name="tab[]" value="t1col1,"/></li>
<li><input type="checkbox" name="tab[]" value="t1col2,"/></li>
<li><input type="checkbox" name="tab[]" value="t1col3,"/></li>
</ul>
</li>
<li>
<input type="checkbox" name="tab[]" value="table2~"/>
<ul>
<li><input type="checkbox" name="tab[]" value="t2col1,"/></li>
<li><input type="checkbox" name="tab[]" value="t2col2,"/></li>
<li><input type="checkbox" name="tab[]" value="t2col3,"/></li>
</ul>
</li>
我可以通過簡單的形式調整和在內循環中添加一個IF來解決問題。
也許這會變:
<form action="tab-cols.php" method="post">
<ul>
<li>
<!-- Changed the name from tab to tab[], so everyone survives -->
<input type="checkbox" name="tab[]" value="table1"/>
<ul>
<li><input type="checkbox" name="cols[]" value="t1col1"</li>
<li><input type="checkbox" name="cols[]" value="t1col2"</li>
<li><input type="checkbox" name="cols[]" value="t1col3"</li>
</ul>
</li>
<li>
<input type="checkbox" name="tab[]" value="table2"/>
<ul>
<li><input type="checkbox" name="cols[]" value="t2col1"></li>
<li><input type="checkbox" name="cols[]" value="t2col2"></li>
<li><input type="checkbox" name="cols[]" value="t2col3"></li>
</ul>
</li>
<ul>
<input type="submit" value="lalala">
</form>
<pre>
<?
$query =" "; //added this
print_r($_POST);
if(isset($_POST['tab']))
{
$t = 1; //added this
foreach($_POST['tab'] as $tabs_entry)
{
$query.=$tabs_entry.'~';
if(isset($_POST['cols']))
{
foreach($_POST['cols'] as $cols_entry){
if(preg_match("/t".$t."(.*)/", $cols_entry) ){ //added this IF, so we can diferentiate
$query = $query.$cols_entry.',';
}
}
$query.="-";
}
$t++; //added this
}
}
echo $query;
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.