PavelMonro
@PavelMonro

Цикл в фильтре битрикс?

Добрый вечер Всем.

Есть код такого вида:
<?
		$res = CIBlockElement::GetList(array(), array("IBLOCK_ID" => 6, "ACTIVE"=>"Y"), false, false, array("ID", "IBLOCK_ID", "PROPERTY_VENDOR"));
		$vendor = array();
		while($ob = $res->GetNextElement()){
			$arFields = $ob->GetFields();
			$vendRes = CIBlockElement::GetByID($arFields["PROPERTY_VENDOR_VALUE"]);
			if($ar_vend = $vendRes->GetNext()){
				if (in_array($ar_vend['NAME'], $vendor) == false){
					$vendor[$ar_vend['ID']] = $ar_vend['NAME'];
				}
			}
		}
		if(!empty($vendor)){
			echo "
<ul class=\"dropdown-menu dropdown-menu-right multi-column columns-3\" aria-labelledby=\"dropdownMenu1\">
<form method='post' action='{$APPLICATION->GetCurDir()}'>
				<input type='hidden' value='Y' name='setfilter'><div class=\"row\">
<div class=\"col-sm-12\">
<ul class=\"multi-column-dropdown\">
				";
			foreach($vendor as $id=>$val):
				if (isset($_SESSION['filter']))
					if (in_array($val, $_SESSION['filter']) || $val == $_SESSION['filter'])
						$checked = ' checked';
					else
						$checked = '';
			?>

				<li>
					<input type="checkbox"<?=$checked?> value="<?=$val?>" name="vendor[]" id="<?=$id?>"><label for="<?=$id?>"><?=$val?></label>
				</li>

			<?
			endforeach;
			echo "
<div class='form-but-wrap'>
					<div class='form-but'><input type='submit' value='Фильтр'></div>
					<div class='form-but'><input type='submit' onclick='filter_clear();' value='Сброс'></div>
					<div class='clear'></div>
				 </div>
</div>
</div></ul>

</form>
</ul>

				";
		}
		?>


Выводит список производителей, как разбить цикл чтобы получился вывод по 5-6 элементов в столбце.

Т.е. сейчас на выходе получается:
<div class="row">
<div class="col-sm-12">
<ul class="multi-column-dropdown">
              
                <li>
                    <input type="checkbox" value="1" name="vendor[]" id="21"><label for="21">1</label>
                </li>


                <li>
                    <input type="checkbox" value="2" name="vendor[]" id="23"><label for="23">2</label>
                </li>


                <li>
                    <input type="checkbox" value="3" name="vendor[]" id="13"><label for="13">3</label>
                </li>


                <li>
                    <input type="checkbox" value="4" name="vendor[]" id="26"><label for="26">4</label>
                </li>


                <li>
                    <input type="checkbox" value="5" name="vendor[]" id="27"><label for="27">5</label>
                </li>


                <li>
                    <input type="checkbox" value="6" name="vendor[]" id="28"><label for="28">6</label>
                </li>
              


                <li>
                    <input type="checkbox" value="7" name="vendor[]" id="29"><label for="29">7</label>
                </li>


                <li>
                    <input type="checkbox" value="8" name="vendor[]" id="16"><label for="16">8</label>
                </li>


                <li>
                    <input type="checkbox" value="9" name="vendor[]" id="25"><label for="25">9</label>
                </li>


                <li>
                    <input type="checkbox" value="10" name="vendor[]" id="20"><label for="20">10</label>
                </li>


                <li>
                    <input type="checkbox" value="11" name="vendor[]" id="14"><label for="14">11</label>
                </li>


                <li>
                    <input type="checkbox" value="12" name="vendor[]" id="17"><label for="17">12</label>
                </li>

                <li>
                    <input type="checkbox" value="13" name="vendor[]" id="24"><label for="24">13</label>
                </li>


                <li>
                    <input type="checkbox" value="14" name="vendor[]" id="19"><label for="19">14</label>
                </li>


                <li>
                    <input type="checkbox" value="15" name="vendor[]" id="18"><label for="18">15</label>
                </li>


                <li>
                    <input type="checkbox" value="16" name="vendor[]" id="1084"><label for="1084">16</label>
                </li>


                <li>
                    <input type="checkbox" value="17" name="vendor[]" id="22"><label for="22">17</label>
                </li>


                <li>
                    <input type="checkbox" value="18" name="vendor[]" id="12"><label for="12">18</label>
                </li>


<div class="form-but-wrap">
                    <div class="form-but"><input type="submit" value="Фильтр"></div>
                    <div class="form-but"><input type="submit" onclick="filter_clear();" value="Сброс"></div>
                    <div class="clear"></div>
                 </div>
</ul></div>
</div>


А мне надо чтобы получилось:
<div class="row">
<div class="col-sm-12">
<ul class="multi-column-dropdown">
              <div class="col-sm-4">  
                <li>
                    <input type="checkbox" value="1" name="vendor[]" id="21"><label for="21">1</label>
                </li>

            
                <li>
                    <input type="checkbox" value="2" name="vendor[]" id="23"><label for="23">2</label>
                </li>

            
                <li>
                    <input type="checkbox" value="3" name="vendor[]" id="13"><label for="13">3</label>
                </li>

            
                <li>
                    <input type="checkbox" value="4" name="vendor[]" id="26"><label for="26">4</label>
                </li>

            
                <li>
                    <input type="checkbox" value="5" name="vendor[]" id="27"><label for="27">5</label>
                </li>

            
                <li>
                    <input type="checkbox" value="6" name="vendor[]" id="28"><label for="28">6</label>
                </li>
                </div>
<div class="col-sm-4">
            
                <li>
                    <input type="checkbox" value="7" name="vendor[]" id="29"><label for="29">7</label>
                </li>

            
                <li>
                    <input type="checkbox" value="8" name="vendor[]" id="16"><label for="16">8</label>
                </li>

            
                <li>
                    <input type="checkbox" value="9" name="vendor[]" id="25"><label for="25">9</label>
                </li>

            
                <li>
                    <input type="checkbox" value="10" name="vendor[]" id="20"><label for="20">10</label>
                </li>

            
                <li>
                    <input type="checkbox" value="11" name="vendor[]" id="14"><label for="14">11</label>
                </li>

            
                <li>
                    <input type="checkbox" value="12" name="vendor[]" id="17"><label for="17">12</label>
                </li>
</div>
            <div class="col-sm-4">
                <li>
                    <input type="checkbox" value="13" name="vendor[]" id="24"><label for="24">13</label>
                </li>

            
                <li>
                    <input type="checkbox" value="14" name="vendor[]" id="19"><label for="19">14</label>
                </li>

            
                <li>
                    <input type="checkbox" value="15" name="vendor[]" id="18"><label for="18">15</label>
                </li>

            
                <li>
                    <input type="checkbox" value="16" name="vendor[]" id="1084"><label for="1084">16</label>
                </li>

            
                <li>
                    <input type="checkbox" value="17" name="vendor[]" id="22"><label for="22">17</label>
                </li>

            
                <li>
                    <input type="checkbox" value="18" name="vendor[]" id="12"><label for="12">18</label>
                </li>
</div>
            
<div class="form-but-wrap">
                    <div class="form-but"><input type="submit" value="Фильтр"></div>
                    <div class="form-but"><input type="submit" onclick="filter_clear();" value="Сброс"></div>
                    <div class="clear"></div>
                 </div>
</ul></div>
</div>
  • Вопрос задан
  • 516 просмотров
Пригласить эксперта
Ответы на вопрос 3
sabramovskikh
@sabramovskikh
Да хоть делите без остатка на N и если делится то выводите нужный разделитель
</div>
            <div class="col-sm-4">
Ответ написан
Комментировать
alexyarik
@alexyarik
Битрикс разработчик
admin4web.ru/uslovie-kratnosti-trem-bitrix - используйте условие кратности где после сработки условия вставляйте закрытие дива и его открытие:
Ответ написан
Ваш ответ на вопрос

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

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