如何将已检查/未检查的复选框值数组传递给PHP电子邮件生成器?

时间:2011-06-16 17:33:04

标签: php arrays forms checkbox

我在表单中添加了一个复选框,用户可以动态添加行。您可以看到表单here

我使用数组将每行的值传递给PHP电子邮件生成器,并且所有这些都适用于其他输入,但我无法使复选框工作。复选框输入目前如下所示:

<input type="checkbox" name="mailing[]" value="Yes">

然后在PHP中我有这个:

$mailing = trim(stripslashes($_POST['mailing'][$i]));

但它没有按预期工作,即我只检查了第一个复选框的“是”,并且没有检查后续复选框。

另一个问题是,我希望为未选中的复选框生成值“否”。

有人可以帮忙吗?

谢谢,

尼克

形式:

<form method="post" action="bookingenginetest.php">
            <p>
                <input type="checkbox" name="mailing[]" value="Yes">
                <label>Full Name:</label> <input type="text" name="name[]">
                <label>Email:</label> <input type="text" name="email[]">
                <label>Telephone:</label> <input type="text" name="telephone[]">
                <span class="remove">Remove</span>
            </p>
            <p>
                <span class="add">Add person</span><br /><br /><input type="submit" name="submit" id="submit" value="Submit" class="submit-button" />
            </p>

        </form>

克隆脚本:

$(document).ready(function() {

                $(".add").click(function() {
                    var x = $("form > p:first-child").clone(true).insertBefore("form > p:last-child");
                    x.find('input').each(function() { this.value = ''; });
                    return false;
                });

                $(".remove").click(function() {
                    $(this).parent().remove();
                });

            });

5 个答案:

答案 0 :(得分:4)

$mailing = array();
foreach($_POST as $v){
    $mailing[] = trim(stripslashes($v));
}

要处理未选中的复选框,最好使用唯一值设置每个复选框:

<input type="checkbox" name="mailing[1]" value="Yes">
<input type="checkbox" name="mailing[2]" value="Yes">

<input type="checkbox" name="mailing[a]" value="Yes">
<input type="checkbox" name="mailing[b]" value="Yes">

然后有一个复选框列表:

$boxes = array(1,2,3);
$mailing = array();
$p = array_key_exists('mailing',$_POST) ? $_POST['mailing'] : array();
foreach($boxes as $v){
    if(array_key_exists($v,$p)){
        $mailing[$v] = trim(stripslashes($p[$v]));
    }else{
        $mailing[$v] = 'No';
    }
}

print_r($mailing);

你也可以使用它来代替多个复选框:

$boxes = 3;
$mailing = array();
$p = array_key_exists('mailing',$_POST) ? $_POST['mailing'] : array();
for($v = 0; $v < $boxes; $v++){
    if(array_key_exists($v,$p)){
        $mailing[$v] = trim(stripslashes($p[$v]));
    }else{
        $mailing[$v] = 'No';
    }
}

print_r($mailing);

答案 1 :(得分:1)

将每个复选框的值更改为唯一的:

<input type="checkbox" name="mailing[]" value="Yes-1"> 
<input type="checkbox" name="mailing[]" value="Yes-2"> 

等。为了从您的jQuery代码执行此操作,添加另一行,将值分配给新复选框:

x.find('input:checkbox').each(function() { this.value='Yes-'+n; }); 

您必须在初始页面加载时定义n。假设您只从一个“人”开始,只需在$(".add").click处理程序上方添加:

var n=1;

然后:

  • $(".add").click处理程序中,增加n
  • 的值
  • 在您的$(".remove").click处理程序中,减少n
  • 的值

答案 2 :(得分:1)

要检查和取消选中POST中的两个值,将放置一个名称完全相同但与原始chkbox值相反的隐藏字段,以便在此情况下值为“0”

<input type="hidden" name="chk_name[]" value="0" />
<input type="checkbox"  name="chk_name[]"  value="1"/>
 <input type="hidden" name="chk_name[]" value="0" />
<input type="checkbox"  name="chk_name[]"  value="1"/>

<?php 
function getAllChkboxValues($chk_name) {
    $found = array(); //create a new array 
    foreach($chk_name as $key => $val) {
        //echo "KEY::".$key."VALue::".$val."<br>";
        if($val == '1') { //replace '1' with the value you want to search
            $found[] = $key;
        }
    }
    foreach($found as $kev_f => $val_f) {
        unset($chk_name[$val_f-1]); //unset the index of un-necessary values in array
    }   
    final_arr = array(); //create the final array
    return $final_arr = array_values($chk_name); //sort the resulting array again
}
$chkox_arr = getAllChkboxValues($_POST['chk_name']); //Chkbox Values
echo"<pre>";
print_r($chkox_arr);
?>

答案 3 :(得分:1)

这是我的解决方案:

html中有一系列复选框,如此......

<input type="hidden" name="something[]" value="off" />
<input type="checkbox" name="something[]" />
<input type="hidden" name="something[]" value="off" />
<input type="checkbox" name="something[]" />
<input type="hidden" name="something[]" value="off" />
<input type="checkbox" name="something[]" />

然后我使用此功能修复已发布的数组......

$_POST[ 'something' ] = $this->fixArrayOfCheckboxes( $_POST[ 'something' ] );
function fixArrayOfCheckboxes( $checks ) {
    $newChecks = array();
    for( $i = 0; $i < count( $checks ); $i++ ) {
        if( $checks[ $i ] == 'off' && $checks[ $i + 1 ] == 'on' ) {
            $newChecks[] = 'on';
            $i++;
        }
        else {
            $newChecks[] = 'off';
        }
    }
    return $newChecks;
}

这将为我提供一个值为&#39; on&#39;或者&#39;关闭&#39;对于每个(和每个)复选框。

请注意隐藏输入必须在复选框输入之前才能使功能正常工作。

答案 4 :(得分:0)

这是我的解决方案:

<span>
<input class="chkBox" onchange="if($(this).is(':checked')){$(this).parent().find('.hidVal').prop('disabled',true);}else{$(this).parent().find('.hidVal').prop('disabled', false);}" type="checkbox" checked name="session[]" value="checked_value_here" />
<input type="hidden" class="hidVal" name="session[]" value="un_checked_value_here" />
</span>
<span>
<input class="chkBox" onchange="if($(this).is(':checked')){$(this).parent().find('.hidVal').prop('disabled',true);}else{$(this).parent().find('.hidVal').prop('disabled', false);}" type="checkbox" checked name="session[]" value="checked_value_here" />
<input type="hidden" class="hidVal" name="session[]" value="un_checked_value_here" />
</span>