立即注冊 找回密碼

QQ登錄

只需一步,快速開始

查看: 275|回復: 0
打印 上一主題 下一主題

[Wordpress 通用教程] WordPress簡單輸出菜單/子菜單的內(nèi)容列表的方法

[復制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
發(fā)表于 2024-8-7 19:55:07 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
道勤網(wǎng)-數(shù)據(jù)bmrsportswear.com

親注冊登錄道勤網(wǎng)-可以查看更多帖子內(nèi)容哦!(包涵精彩圖片、文字詳情等)請您及時注冊登錄-bmrsportswear.com

您需要 登錄 才可以下載或查看,沒有賬號?立即注冊

x
在定制網(wǎng)站的時候,高效利用菜單可以節(jié)約很多開發(fā)時間。比如要輸出一系列的相關頁面,我們可以新建一個菜單,把這些頁面都放到菜單里,然后用“wp_nav_menu”方法輸出這些菜單項,比如這樣。

  1. wp_nav_menu( array(
  2.         'theme_location' => 'menu-top'
  3. ) );
復制代碼
wp_nav_menu是一個已經(jīng)高度封裝的輸出函數(shù),你可以通過注入?yún)?shù)自定義各種標簽和樣式,具體可以查看官方文檔(https://developer.wordpress.org/reference/functions/wp_nav_menu/),本文就不贅述了。但有一個問題它沒有辦法解決,也就是只輸出特定的子菜單項,而不是整個菜單的菜單樹。
假如我通過wp_nav_menu方法可以輸出以下這個菜單,我需要在某些地方只輸出圈出的這塊子菜單,有什么方法可以做到嗎?
自然是有的,我們可以借助wp_get_nav_menu_items這個封裝讀沒有wp_nav_menu那么高的函數(shù)來解決。直接上代碼:
  1. $parent_item_id = 888; //change this id by your needs
  2. $menu_items = wp_get_nav_menu_items( $navigation_attributes['menu_id'] );
  3. $menu_html = '';
  4. for ( $x = 0; $x < count( $menu_items ); $x++ ) {
  5.         $menu_item_parent = $menu_items[ $x ]->menu_item_parent;
  6.         if( $menu_item_parent == $parent_item_id ){
  7.                 $url = $menu_items[ $x ]->url;
  8.                 $title = $menu_items[ $x ]->title;
  9.                 $menu_html .= '<li><a href="' .esc_attr( esc_url( $url ) ). '">' .wp_kses_post( $title ).'</a></li>';
  10.         }
  11. }
  12. echo $menu_html;
復制代碼
修改第一行的$parent_item_id 即可輸出對應子菜單項了。$parent_item_id是一個數(shù)字,可以在菜單設置界面的控制臺里找到:
接下來我們再加工一下功能,要知道wp_nav_menu是可以標記當前頁面的,它會給當前頁的項加一個”current_page_item”樣式,我們可以利用這個樣式對當前頁做一些高亮顯示等交互處理。我希望在調(diào)用子菜單的時候也能有類似功能。并且我們也要封裝一個短代嗎以便在后臺編輯器中隨時實用,下面是完整代碼:
  1. //Out put submenu items in certain menu - https://blog.brain1981.com
  2. //load navigation shortcode
  3. add_shortcode( 'brain1981_custom_navigation', 'brain1981_add_custom_navigation' );
  4. //create shortcode for navigation
  5. function brain1981_add_custom_navigation( $attributes, $content = null ) {
  6.         $navigation_attributes = shortcode_atts( array(
  7.                 'menu_id' => '',
  8.                 'parent_item_id' => '',
  9.         ), $attributes );
  10.         $menu_items = wp_get_nav_menu_items( $navigation_attributes['menu_id'] );
  11.         $menu_html = '';
  12.         $current_page_url = get_permalink( get_queried_object_id() );

  13.         for ( $x = 0; $x < count( $menu_items ); $x++ ) {
  14.                 $menu_item_parent = $menu_items[ $x ]->menu_item_parent;
  15.                 if( $menu_item_parent == $navigation_attributes['parent_item_id'] ){
  16.                         $url = $menu_items[ $x ]->url;
  17.                         $is_current = '';
  18.                         if( $current_page_url == $url) $is_current = 'current';
  19.                         $title = $menu_items[ $x ]->title;
  20.                         $item_id = $menu_items[ $x ]->post_slug;
  21.                         $menu_html .= '<li class="'.$is_current.'"><a href="' .esc_attr( esc_url( $url ) ). '">' .wp_kses_post( $title ).'</a></li>';
  22.                 }
  23.         }
  24.         return '<u>'.$menu_html.'</ul>';
  25. }
復制代碼
以上代碼中,參數(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)站零訪問延遲的遷移到道勤主機的服務!
本內(nèi)容系 道勤團隊 bmrsportswear.com 客服與技術人員研究整理的智慧結晶,轉(zhuǎn)載勿用于商業(yè)用途,并保留本文鏈接,侵權必究!
dsu_marcocopyright:copy_link 

【道勤網(wǎng)】- bmrsportswear.com 軟件視頻自學教程|免費教程|自學電腦|3D教程|平面教程|影視動畫教程|辦公教程|機械設計教程|網(wǎng)站設計教程!【道勤網(wǎng)】 - 論壇版權1、本主題所有言論和圖片純屬會員個人意見,與本論壇立場無關
2、本站所有主題由該帖子作者發(fā)表,該帖子作者與【道勤網(wǎng)】- bmrsportswear.com 軟件視頻自學教程|免費教程|自學電腦|3D教程|平面教程|影視動畫教程|辦公教程|機械設計教程|網(wǎng)站設計教程!【道勤網(wǎng)】享有帖子相關版權
3、其他單位或個人使用、轉(zhuǎn)載或引用本文時必須同時征得該帖子作者和【道勤網(wǎng)】- bmrsportswear.com 軟件視頻自學教程|免費教程|自學電腦|3D教程|平面教程|影視動畫教程|辦公教程|機械設計教程|網(wǎng)站設計教程!【道勤網(wǎng)】的同意
4、帖子作者須承擔一切因本文發(fā)表而直接或間接導致的民事或刑事法律責任
5、本帖部分內(nèi)容轉(zhuǎn)載自其它媒體,但并不代表本站贊同其觀點和對其真實性負責
6、如本帖侵犯到任何版權問題,請立即告知本站,本站將及時予與刪除并致以最深的歉意
7、【道勤網(wǎng)】- bmrsportswear.com 軟件視頻自學教程|免費教程|自學電腦|3D教程|平面教程|影視動畫教程|辦公教程|機械設計教程|網(wǎng)站設計教程!【道勤網(wǎng)】管理員和版主有權不事先通知發(fā)貼者而刪除本文

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

關閉

道勤網(wǎng)- 推薦內(nèi)容!上一條 /2 下一條

!jz_fbzt! !jz_sgzt! !jz_xgzt! 快速回復 !jz_fhlb! !jz_lxwm! !jz_gfqqq!

關于我們|手機版|小黑屋|地圖|【道勤網(wǎng)】-bmrsportswear.com 軟件視頻自學教程|免費教程|自學電腦|3D教程|平面教程|影視動畫教程|辦公教程|機械設計教程|網(wǎng)站設計教程【道勤網(wǎng)】 ( 皖ICP備15000319號-1 )

GMT+8, 2024-9-25 03:43

Powered by DaoQin! X3.4 © 2016-2063 Dao Qin & 道勤科技

快速回復 返回頂部 返回列表