Задать вопрос
@m4f1

Как отсортировать по алфавиту?

Помогите поймать названия цветов и отсортировать их по алфавиту.

Сам список цветов находится в dropbox, подгружается все запросами из бд (система сайта webasyst), сейчас формируется список по id элементов. Цвета вместе с ссылкой подставляются в (нет, функцию переписать возможности нет, нужно именно javascript/jquery)
ac5baa0ad4.jpg

Кусок кода html страницы:
<select id="sort_sel" name="tsvet1[]">																				    
<option data-urll="" value="">Не выбрано</option>
<option data-urll="?tsvet1%5B0%5D=27" value="27">чёрный</option>
<option data-urll="?tsvet1%5B0%5D=34" value="34">синий</option>
<option data-urll="?tsvet1%5B0%5D=44" value="44">переливающийся</option>
<option data-urll="?tsvet1%5B0%5D=54" value="54">голубой</option>
<option data-urll="?tsvet1%5B0%5D=48" value="48">бирюзовый</option>
<option data-urll="?tsvet1%5B0%5D=35" value="35">зелёный</option>
<option data-urll="?tsvet1%5B0%5D=53" value="53">камуфляж</option>
<option data-urll="?tsvet1%5B0%5D=29" value="29">серый</option>
<option data-urll="?tsvet1%5B0%5D=39" value="39">фиолетовый</option>
<option data-urll="?tsvet1%5B0%5D=50" value="50">с рисунком</option>
<option data-urll="?tsvet1%5B0%5D=46" value="46">коричневый</option>
<option data-urll="?tsvet1%5B0%5D=31" value="31">серебро</option>
<option data-urll="?tsvet1%5B0%5D=55" value="55">пурпурный</option>
<option data-urll="?tsvet1%5B0%5D=52" value="52">металлик</option>
<option data-urll="?tsvet1%5B0%5D=51" value="51">бежевый</option>
<option data-urll="?tsvet1%5B0%5D=32" value="32">розовое золото</option>
<option data-urll="?tsvet1%5B0%5D=33" value="33">красный</option>
<option data-urll="?tsvet1%5B0%5D=45" value="45">оранжевый</option>
<option data-urll="?tsvet1%5B0%5D=41" value="41">разноцветный</option>
<option data-urll="?tsvet1%5B0%5D=49" value="49">розовый</option>
<option data-urll="?tsvet1%5B0%5D=30" value="30">золото</option>
<option data-urll="?tsvet1%5B0%5D=36" value="36">жёлтый</option>
<option data-urll="?tsvet1%5B0%5D=28" value="28">белый</option>
<option data-urll="?tsvet1%5B0%5D=37" value="37">прозрачный</option>
</select>


Кусок внутреннего кода:
{foreach $filters as $fid => $filter}

	{if $fid == 'price'}{continue}{/if}
	<div class="flex_block for-market-sort" data-piwik-category="category" data-piwik-name="filters_{$filter.code}">
		<label for="sort_sel">{$filter.name|escape}:</label>
		{if !empty($ids[$fid])}
			{$filterUnavailable = !array_intersect_key(array_flip($ids[$fid]), $filter.values)}
		{else}
			{$filterUnavailable = 1}
		{/if}

		<select id="sort_sel" name='{$filter.code}[]' class="filter_select">

			{if 1}

{$i = 0}

{foreach $filter.values as $v_id => $v}
	{if $v == 'Не выбрано'}
		<option data-urll="{shopMypluginPlugin::href_query_string2($filter.code, false)}" value="">Не выбрано</option>
	{else}    
		{if $i == 0 }
			<option data-urll="{shopMypluginPlugin::href_query_string2($filter.code, false)}" value="">Не выбрано</option>
			{$i = 1}
		{/if}

		{if 1 OR in_array($v_id, $availibleIDs[$fid])}

			<option data-urll="{shopMypluginPlugin::href_query_string2($filter.code, $v_id)}"
			
			{if !empty($codes[$v_id])} 
				data-url='{$codes[$v_id]}'
			{/if}
			
			{if !empty($active_url[{$filter.code}])}

				{if in_array($v_id, $active_url[{$filter.code}])} 
				selected
				{/if}
			{/if} value="{$v_id}">
			
			{if is_array($v)}
			{shopMypluginPlugin::my_trim(shopMypluginPlugin::my_mb_ucfirst(strip_tags($v.value)))|escape}
			
			{else}
				{shopMypluginPlugin::my_trim(shopMypluginPlugin::my_mb_ucfirst(strip_tags($v)))|escape}
			{/if}
			
			</option>
		{/if}
	{/if}
{/foreach}
				{if 0}</optgroup>{/if}
			{/if}
		</select>
	</div>
{/foreach}


Таким образом не выходит, пишет result not found (нужно выделить конкретные элементы, как я понял):
$(document).ready(function() {
	$("#sort_sel").html($('#sort_sel option').sort(function(x, y) {
		return $(x).text() < $(y).text() ? -1 : 1;
	}))
	//$("#sort_sel").get(0).selectedIndex = 0;
	//e.preventDefault();
});
  • Вопрос задан
  • 256 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
Deonisius
@Deonisius
Родился в 11110110111 году, 11000 января.
const select = $('#sort_sel');
select.find('option:not(:first-child)').sort(function(a, b) {
  var sa = a.textContent.toLowerCase(),
    sb = b.textContent.toLowerCase();
  return sb < sa ? 1 : sb > sa ? -1 : 0;
}).appendTo(select);

https://jsfiddle.net/Deonis/t2Lw9agp/

P.S. Селектор, скорее всего, что лучше такой: select.find('option:not([value=""])')
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы