Сценарий:
У меня есть меню, содержащее ссылки:
Main Menu Item
--------------
Sub: Show Grid > SubSub: <a>Show #first</a>
<a>Show #second</a>
<a>Show #third</a>
Теперь мне нужно найти все div с css #ID
, которые являются элементами уровня DOM первого уровня внутри div .container
. Эти элементы должны добавляться к "Sub: Show Grid" и добавлять класс через клик по нему.
<!-- The mark up -->
<div class="container">
<div id="first">1st</div>
<div id="second">2nd</div>
<div id="third">3rd</div>
</div>
Вопрос:
- Как я могу найти div первого уровня с (undefined/not known)
#ID
с помощью jQuery? - Как я могу взаимодействовать с результатом в php - я получу массив в качестве результата для создания из него меню SubSub?
Спасибо заранее!
Изменить # 1
Чтобы было более ясно, что я пытаюсь сделать - в псевдокоде:
$divs_received_from_jquery_fn = 'how do I get the divs (IDs?) as array(?) and interact with them in the following code?';
foreach ( $divs_received_from_jquery_fn as $div )
{
add_menu_item( array(
'parent' => 'Sub: Show Grid'
,'name' => 'Show #'.$div
,'href' => ''
,'meta' => array(
'onclick' => 'jQuery(".container #".$div).toggleClass("showgrid");'
)
) );
}
Изменить # 2
Пример "реального мира". Вывод - это событие onclick для a-link. Моя проблема в том, что я хочу вызвать функцию foreach
для каждого div[id]
под .container
div и просто не знаю, как правильно взаимодействовать с javascript и php.
?>
<script type="text/javascript">
jQuery(".container > div[id]").each(function(){
var context = $(this);
<?php
// SHOWGRID - parts
// @since v0.3
$wp_admin_bar->add_menu( // trigger the function via the global $wp_admin_bar var that calls the class
array(
'parent' => 'showgrid' // parent menu item
,'id' => 'showgrid - ' + this.id // menu item ID
,'title' => sprintf( // menu item label
__( '%1$s show grid parts %2$s%3$s', OXO_TEXTDOMAIN )
,'<span style="background: none;">'
,'<span class="showgridparts-on hide">✔</span>'
,'<span class="showgridparts-off">×</span>'
)
,'href' => '' // stays empty to not trigger anything
,'meta' => array( // HERE GOES THE ACTUAL jQuery FUNCTION
'onclick' => 'jQuery("#" + this.id).toggleClass("showgrid"); jQuery(".showgridparts-on").toggleClass("hide"); jQuery(".showgridparts-off").toggleClass("hide"); return false;'
)
)
);
?>
});
</script>
<?php