親注冊登錄道勤網(wǎng)-可以查看更多帖子內(nèi)容哦!(包涵精彩圖片、文字詳情等)請您及時注冊登錄-bmrsportswear.com
您需要 登錄 才可以下載或查看,沒有賬號?立即注冊
x
在定制網(wǎng)站的時候,高效利用菜單可以節(jié)約很多開發(fā)時間。比如要輸出一系列的相關頁面,我們可以新建一個菜單,把這些頁面都放到菜單里,然后用“wp_nav_menu”方法輸出這些菜單項,比如這樣。
- wp_nav_menu( array(
- 'theme_location' => 'menu-top'
- ) );
復制代碼假如我通過wp_nav_menu方法可以輸出以下這個菜單,我需要在某些地方只輸出圈出的這塊子菜單,有什么方法可以做到嗎?
01.jpg (35.69 KB, 下載次數(shù): 6)
下載附件
2024-8-7 19:52 上傳
自然是有的,我們可以借助wp_get_nav_menu_items這個封裝讀沒有wp_nav_menu那么高的函數(shù)來解決。直接上代碼: - $parent_item_id = 888; //change this id by your needs
- $menu_items = wp_get_nav_menu_items( $navigation_attributes['menu_id'] );
- $menu_html = '';
- for ( $x = 0; $x < count( $menu_items ); $x++ ) {
- $menu_item_parent = $menu_items[ $x ]->menu_item_parent;
- if( $menu_item_parent == $parent_item_id ){
- $url = $menu_items[ $x ]->url;
- $title = $menu_items[ $x ]->title;
- $menu_html .= '<li><a href="' .esc_attr( esc_url( $url ) ). '">' .wp_kses_post( $title ).'</a></li>';
- }
- }
- echo $menu_html;
復制代碼修改第一行的$parent_item_id 即可輸出對應子菜單項了。$parent_item_id是一個數(shù)字,可以在菜單設置界面的控制臺里找到:
022.jpg (173 KB, 下載次數(shù): 12)
下載附件
2024-8-7 19:53 上傳
接下來我們再加工一下功能,要知道wp_nav_menu是可以標記當前頁面的,它會給當前頁的項加一個”current_page_item”樣式,我們可以利用這個樣式對當前頁做一些高亮顯示等交互處理。我希望在調(diào)用子菜單的時候也能有類似功能。并且我們也要封裝一個短代嗎以便在后臺編輯器中隨時實用,下面是完整代碼: - //Out put submenu items in certain menu - https://blog.brain1981.com
- //load navigation shortcode
- add_shortcode( 'brain1981_custom_navigation', 'brain1981_add_custom_navigation' );
- //create shortcode for navigation
- function brain1981_add_custom_navigation( $attributes, $content = null ) {
- $navigation_attributes = shortcode_atts( array(
- 'menu_id' => '',
- 'parent_item_id' => '',
- ), $attributes );
- $menu_items = wp_get_nav_menu_items( $navigation_attributes['menu_id'] );
- $menu_html = '';
- $current_page_url = get_permalink( get_queried_object_id() );
-
- for ( $x = 0; $x < count( $menu_items ); $x++ ) {
- $menu_item_parent = $menu_items[ $x ]->menu_item_parent;
- if( $menu_item_parent == $navigation_attributes['parent_item_id'] ){
- $url = $menu_items[ $x ]->url;
- $is_current = '';
- if( $current_page_url == $url) $is_current = 'current';
- $title = $menu_items[ $x ]->title;
- $item_id = $menu_items[ $x ]->post_slug;
- $menu_html .= '<li class="'.$is_current.'"><a href="' .esc_attr( esc_url( $url ) ). '">' .wp_kses_post( $title ).'</a></li>';
- }
- }
- return '<u>'.$menu_html.'</ul>';
- }
復制代碼以上代碼中,參數(shù)menu_id即菜單ID,parent_item_id即上面提到的子菜單ID,輸出的菜單項如果是當前頁面,會自動生成“current”的樣式。自此,使用如下短代嗎即可隨時調(diào)用指定的子菜單 [brain1981_custom_navigation menu_id=123 parent_item_id=60] 這樣就可以了
道勤主機提供365天*24小時全年全天無休、實時在線、零等待的售后技術支持。竭力為您免費處理您在使用道勤主機過程中所遇到的一切問題!
如果您是道勤主機用戶,那么您可以通過QQ【792472177】、售后QQ【59133755】、旺旺【詮釋意念】、微信:q792472177免費電話、后臺提交工單這些方式聯(lián)系道勤主機客服!
如果您不是我們的客戶也沒問題,點擊頁面最右邊的企業(yè)QQ在線咨詢圖標聯(lián)系我們并購買后,我們?yōu)槟赓M進行無縫搬家服務,讓您享受網(wǎng)站零訪問延遲的遷移到道勤主機的服務! |