Как выбрать все входы с одинаковым именем и проиндексировать их по имени - PullRequest
13 голосов
/ 08 февраля 2012

Я должен обработать форму, созданную третьей частью. Эта форма предоставляет некоторые флажки «множественный выбор» атрибутов. Но входные имена идентичны, и PHP $ _POST не может обрабатывать идентичные ключи (обрабатываются только последние данные).

Вот пример формы:

<form>
    <input type="checkbox" name="attr1" value="1" />
    <input type="checkbox" name="attr1" value="2" />
    <input type="checkbox" name="attr1" value="3" />
    <input type="checkbox" name="attr1" value="4" />
    <input type="checkbox" name="attr2" value="xx" />
    <input type="checkbox" name="attr3" value="a" />
    <input type="checkbox" name="attr3" value="b" />
    <input type="checkbox" name="attr3" value="c" />
    <input type="checkbox" name="attr3" value="d" />
    <input type="text" name="attr4" value="" />
</form>

Я хотел бы проанализировать все входы флажков, получить только группу входов с одинаковыми именами и добавить "[]" к их имени ...

Что я хочу получить после обработки jQuery:

<form>
    <input type="checkbox" name="attr1[]" value="1" />
    <input type="checkbox" name="attr1[]" value="2" />
    <input type="checkbox" name="attr1[]" value="3" />
    <input type="checkbox" name="attr1[]" value="4" />
    <input type="checkbox" name="attr2" value="xx" />
    <input type="checkbox" name="attr3[]" value="a" />
    <input type="checkbox" name="attr3[]" value="b" />
    <input type="checkbox" name="attr3[]" value="c" />
    <input type="checkbox" name="attr3[]" value="d" />
    <input type="text" name="attr4" value="" />
</form>

Есть ли способ идентифицировать группу входов с одинаковым именем?

Ответы [ 5 ]

21 голосов
/ 08 февраля 2012

Это добавит [] к имени каждого элемента флажка, если существует другой элемент с тем же именем.

var name_map = {};
$("input[type=checkbox]")  // for all checkboxes
    .each(function() {  // first pass, create name mapping
        var name = this.name;
        name_map[name] = (name_map[name]) ? name + "[]" : name;
    })
    .each(function() {  // replace name based on mapping
        this.name = name_map[this.name];
    });

Демо: http://jsfiddle.net/gnfsG/

4 голосов
/ 08 февраля 2012

Попробуйте это:

var group = $('input[name="attr1"]');

if (group.length > 1){
   group.each(function () {
        $(this).attr("name",$(this).attr("name")+"[]");
   });
}
1 голос
/ 08 февраля 2012

Вам нужно будет использовать $('input[name^="attr"]') в вашем случае. Поскольку ваши предметы имеют attr1, attr2, attr3 и т. Д. Вышеупомянутый селектор будет соответствовать всем.

Вы можете проверить это в действии @ http://jsfiddle.net/cT78Y/2/

$('input[name^="attr"]:checkbox').each(function(i){
   $(this).attr("name",$(this).attr("name")+"[]");
});

Это даст вам.

<form>
  <input type="checkbox" name="attr1[]" value="1">
  <input type="checkbox" name="attr1[]" value="2">
  <input type="checkbox" name="attr1[]" value="3">
  <input type="checkbox" name="attr1[]" value="4">
  <input type="checkbox" name="attr2[]" value="xx">
  <input type="checkbox" name="attr3[]" value="a">
  <input type="checkbox" name="attr3[]" value="b">
  <input type="checkbox" name="attr3[]" value="c">
  <input type="checkbox" name="attr3[]" value="d">
  <input type="text" name="attr4" value="">
</form>

Надеюсь, это поможет вам.

0 голосов
/ 05 января 2016
$("input[name=attr\\[\\]]");

получить все входные данные, где имя = attr[]

0 голосов
/ 08 февраля 2012

Это очень длинное решение

var array =[];
                $('input[type="checkbox"]').each(function(){
                    array.push($(this).attr('name'));
                });

                var sorted_arr = array.sort(); // You can define the comparing function here.
                // JS by default uses a crappy string compare.
                var results = [];
                for (var i = 0; i < array.length - 1; i++) {
                    if (sorted_arr[i + 1] == sorted_arr[i]) {
                        results.push(sorted_arr[i]);
                    }
                }
                var names = [];
                names = jQuery.unique(results);
                $.each(names ,function(key,value){
                    $('input[name ="'+value+'"]').attr("name",value+"[]");
                });
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...