Подтвердить что ты не робот

Массивы POST, не отображающие отмеченные флажки

Не удается получить мои массивы POST, чтобы показать все флажки в моей форме.

У меня есть форма, настроенная следующим образом:

<form name='foo' method='post' action=''>
    <table>
       <tr>
          <td class='bla'>Checkbox: <input type='checkbox' name='cBox[]'/></td>
      </tr>
       <tr>
          <td class='bla'>Checkbox: <input type='checkbox' name='cBox[]'/></td>
      </tr>
       <tr>
          <td class='bla'>Checkbox: <input type='checkbox' name='cBox[]'/></td>
      </tr>
   </table>
</form>

У меня есть кнопка внизу, связанная с функцией jquery, которая добавляет еще 5 пустых строк в форму (следовательно, массивы для имени ввода cBox []).

Теперь проблема. Предположим, что первый флажок снят, и проверены последние 2. Когда я вывожу значения (используя PHP print_r для отладки), я получу:

Array ( [0] => on [1] => on)

По какой-то причине массив не содержит значения для снятых флажков.

Я видел некоторые решения, в которых скрытая переменная передается с каждым флажком, но может ли это решение быть реализовано в моей ситуации (используя массивы)?

4b9b3361

Ответ 1

Это поведение неудивительно, так как браузер не передает никаких значений для отмеченных флажков.

Если вы находитесь в ситуации, когда вам нужно представить точное количество элементов в виде массива, почему бы вам не сделать то же самое, что и вы, когда есть id определенного типа, связанного с каждым флажком? Просто укажите имя ключа массива PHP как часть имени элемента <input>:

  <tr>
                                                       <!-- NOTE [0] --->
      <td class='bla'>Checkbox: <input type='checkbox' name='cBox[0]'/></td>
  </tr>
   <tr>
      <td class='bla'>Checkbox: <input type='checkbox' name='cBox[1]'/></td>
  </tr>
   <tr>
      <td class='bla'>Checkbox: <input type='checkbox' name='cBox[2]'/></td>
  </tr>

Это все еще оставляет вам проблему с тем, что необработанные поля все равно не будут присутствовать в массиве. Это может быть или не быть проблемой. Во-первых, вам действительно не все равно:

foreach($incoming as $key => $value) {
    // if the first $key is 1, do you care that you will never see 0?
}

Даже если вам все равно, вы можете легко исправить проблему. Здесь есть два простых подхода. Во-первых, просто выполните трюк скрытого ввода:

  <tr>
      <td class='bla'>
        <input type="hidden" name="cBox[0]" value="" />
        Checkbox: <input type='checkbox' name='cBox[0]'/>
      </td>
  </tr>
   <tr>
      <td class='bla'>
        <input type="hidden" name="cBox[1]" value="" />
        Checkbox: <input type='checkbox' name='cBox[1]'/>
      </td>
  </tr>

И два, которые я считаю предпочтительными, вместо этого заполняйте пробелы из PHP:

// assume this is what comes in:
$input = array(
    '1' => 'foo',
    '3' => 'bar',
);

// set defaults: array with keys 0-4 all set to empty string
$defaults = array_fill(0, 5, '');

$input = $input + $defaults;
print_r($input);

// If you also want order, sort:

ksort($input);
print_r($input);

Посмотрите на действие.

Ответ 2

ONE TRICK должен переопределить значение флажка, если отмечено. в противном случае его значение будет равно 0.

<form>
  <input type='hidden' value='0' name="smth">
  <input type='checkbox' value='1' name="smth">
</form>

Ответ 3

Try

<input type='checkbox' value="XXX" name='cBox[]'/>
<input type='checkbox' value="YYY" name='cBox[]'/>
<input type='checkbox' value="ZZZ" name='cBox[]'/>

Флажки работают таким образом. Если он отмечен, только после этого значение опубликовано.

Ответ 4

Если вы работаете с динамическим блоком checkbox, вы можете попробовать следующее:

HTML:

<label>
  <input type="hidden" name="cBox[]" value="" />
  <input type="checkbox" class="checkbox" value="on" />
</label>
<label>
  <input type="hidden" name="cBox[]" value="" />
  <input type="checkbox" class="checkbox" value="on" />
</label>
<!-- extend -->

Javascript (jQuery):

$(document).on("change", "input.checkbox", function() {

    var value = $(this).is(":checked") ? $(this).val() : null;

    $(this).siblings("input[name='cBox[]']").val(value);    
});

Результат бэкэнд (если проверен только второй):

// PHP $_POST['cBox']
Array
(
    [0] => 
    [1] => on
)

В этом инструменте флажки используются для управления каждым скрытым входом в группе.

Для отображения страницы вы можете отобразить каждую пару входов обратно, присвоив значение в скрытые входы и отметки в качестве checked.

Ответ 5

Попробуйте установить значение для каждого флажка, равного 1 или true.

<input type='checkbox' value='1' name='cBox[1]'/>

может быть, почему он ничего не отправляет?