Неизвестная переменная с подстановочными знаками в селекторе jQuery
HTML
<select id="edit-attributes-1"></select>
<select id="edit-attributes-2"></select>
<select id="edit-attributes-3"></select>
<select id="edit-attributes-4"></select>
Это генерируется CMS, и я ничего не могу сделать
Jquery:
$('select[id^="edit-attributes-"][id!="edit-attributes-12"]').after('<span class="step stepdown step-'+$(this).attr('id')+'">+</span>');
поэтому я создал это, так как попытка jquery.ui.spinner проблематична при определении элементов.
НОТА:
$(this).attr('id') here results as unknown.
Результаты
<select id="edit-attributes-1"></select>
<span class="step stepdown step-**unknown**">+</span>
<select id="edit-attributes-2"></select>
<span class="step stepdown step-**unknown**">+</span>
<select id="edit-attributes-3"></select>
<span class="step stepdown step-**unknown**">+</span>
<select id="edit-attributes-4"></select>
<span class="step stepdown step-**unknown**">+</span>
Как видите, часть $(this).attr('id') неизвестна.
Желаемые результаты
<select id="edit-attributes-1"></select>
<span class="step stepdown step-**edit-attributes-1**">+</span>
<select id="edit-attributes-2"></select>
<span class="step stepdown step-**edit-attributes-2**">+</span>
<select id="edit-attributes-3"></select>
<span class="step stepdown step-**edit-attributes-3**">+</span>
<select id="edit-attributes-4"></select>
<span class="step stepdown step-**edit-attributes-4**">+</span>
Я не знаю, как я смог достичь такой концепции, или, пожалуйста, представьте лучший способ упростить вещи. Может кто-нибудь показать мне путь джедая.
2 ответа
Решение
this
в вашем коде не относится к выбранным вами элементам, вы можете использовать after
функция:
$('select[id^="edit-attributes-"][id!="edit-attributes-12"]').after(function(ind){
return '<span class="step stepdown step-'+ this.id +'">+</span>'
});
Попробуйте этот код:
$('select[id^="edit-attributes-"][id!="edit-attributes-12"]').each(function () {
var this_selection = $(this);
var selection_id = this_selection.attr('id');
this_selection.after('<span class="step stepdown step-' + selection_id + '"></span>');
});