как получить каждую переменную в одну строку - PullRequest
0 голосов
/ 08 ноября 2018
<div class="auswahl">
    <select id="1Riegel">
        <option value="Mix">Mix</option>
        <option value="Schoko">Schoko</option>
        <option value="Frucht">Frucht</option>
    </select>
    <select "id="1Shake">
        <option value="Mix">Mix</option>
        <option value="Schoko">Schoko</option>
        <option value="Vanille">Vanille</option>
    </select>
</div>

var check_attribute = $(this).parents('div.produkt').find('select');
$.each(check_attribute, function (index, value) {
    var name  = $(this).attr('id'),
    wert  = ' ' + $(value).find('option:selected').val();
    attribute = name.substring(1)+wert;
    console.log(attribute);
});

это выдаст:

Ригель Фрухт
Shake Schoko

в консоли ... но мне нужно в одну строку, например:

Ригель Фрухт - Шейк Шоко

Кто-нибудь может мне помочь с этим пожалуйста?

Ответы [ 2 ]

0 голосов
/ 08 ноября 2018

Вместо этого вы можете использовать .map, чтобы получить массив всех <select> и выбранных строк параметров, а затем соединить эти строки с помощью -:

const output = $('select').map(function() {
  return $(this).attr('id').slice(1) + ' ' + $(this).find('option:selected').val();
})
  .get()
  .join(' - ');

console.log(output);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="auswahl">
  <select id="1Riegel">
    <option value="Mix">Mix</option>
    <option value="Schoko">Schoko</option>
    <option value="Frucht" selected>Frucht</option>
  </select>
  <select id="1Shake ">
    <option value="Mix ">Mix</option>
    <option value="Schoko " selected>Schoko</option>
    <option value="Vanille ">Vanille</option>
  </select>
</div>

Или вы можете полностью отказаться от jQuery, не нужно включать большую библиотеку для чего-то такого простого:

const output = Array.prototype.map.call(
  document.querySelectorAll('select'),
  select => select.id.slice(1) + ' ' + select.value
)
  .join(' - ');
  
  
console.log(output);
<div class="auswahl">
  <select id="1Riegel">
    <option value="Mix">Mix</option>
    <option value="Schoko">Schoko</option>
    <option value="Frucht" selected>Frucht</option>
  </select>
  <select id="1Shake ">
    <option value="Mix ">Mix</option>
    <option value="Schoko " selected>Schoko</option>
    <option value="Vanille ">Vanille</option>
  </select>
</div>
0 голосов
/ 08 ноября 2018
var line = '';
var check_attribute = $(this).parents('div.produkt').find('select');
$.each(check_attribute, function (index, value) {
      var name = $(this).attr('id'),
      wert = ' ' + $(value).find('option:selected').val();
      attribute = name.substring(1) + wert;
      if(line.lenght>0){
       line += " - ";
      }
      line +=  attribute;
 });
console.log(line);

Этот сервер цель

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...