問題描述
有沒有辦法,我可以硬編碼的第一個主題安裝時的自定義選單項?我正在建立一個主題,它將在安裝時自動使一些常見頁面。所以我需要知道,如果我也可以新增到 Wordpress 自定義選單,所以客戶端不需要手動新增它們?
換句話說:如何以程式設計方式插入/建立自定義選單項?
讓我知道如果有什麼不清楚的話。歡迎指導適當的 codex 頁面。謝謝!
更新:嘗試程式碼從這裡 Targeting specific menu with wp_nav_menu_items
選單註冊:
function register_my_menus() {
register_nav_menus(
array('main-menu' => __( 'Main Menu' ) )
);
}
add_action( 'init', 'register_my_menus' );
模板使用:
<?php wp_nav_menu( array( 'theme_location' => 'main-menu' ) ); ?>
新增新專案的程式碼:
function new_nav_menu_items($items) {
if( $args->theme_location == 'main-menu' ){
$homelink = '<li class="home"><a href="http://'%20.%20home_url(%20'/'%20)%20.%20'">' . __('Home') . '</a></li>';
$items = $homelink . $items;
return $items;
}
}
add_filter( 'wp_nav_menu_items', 'new_nav_menu_items', 10, 2 );
當在 functions.php 檔案中的導航選單中新增新增新專案的程式碼時,在管理面板的選單頁面中會發生錯誤,但是當前的選單專案已經停留在站點中!
最佳解決方案
你的程式碼的問題是,它實際上並沒有新增到選單的連結,而只是新增到選單的輸出,因此使用過濾器 (add_filter),所以你只是過濾選單的輸出,即使你不有一個選單,您的連結將顯示您正在使用的程式碼。但是要建立一個連結並將其新增到選單中,您可以使用以下程式碼:
$run_once = get_option('menu_check');
if (!$run_once){
//give your menu a name
$name = 'theme default menu';
//create the menu
$menu_id = wp_create_nav_menu($name);
//then get the menu object by its name
$menu = get_term_by( 'name', $name, 'nav_menu' );
//then add the actuall link/ menu item and you do this for each item you want to add
wp_update_nav_menu_item($menu->term_id, 0, array(
'menu-item-title' => __('Home'),
'menu-item-classes' => 'home',
'menu-item-url' => home_url( '/' ),
'menu-item-status' => 'publish'));
//then you set the wanted theme location
$locations = get_theme_mod('nav_menu_locations');
$locations['main-menu'] = $menu->term_id;
set_theme_mod( 'nav_menu_locations', $locations );
// then update the menu_check option to make sure this code only runs once
update_option('menu_check', true);
}
我已經評論過,讓它更簡單。
要建立一個子頁面/子頁面/第二級選單 (如何呼叫它),您只需要在新專案中設定 menu-item-parent-id,例如:
//create the top level menu item (home)
$top_menu = wp_update_nav_menu_item($menu->term_id, 0, array(
'menu-item-title' => __('Home'),
'menu-item-classes' => 'home',
'menu-item-url' => home_url( '/' ),
'menu-item-status' => 'publish'
'menu-item-parent-id' => 0,
));
//Sub menu item (first child)
$first_child = wp_update_nav_menu_item($menu->term_id, 0, array(
'menu-item-title' => __('First_Child'),
'menu-item-classes' => 'home',
'menu-item-url' => home_url( '/' ),
'menu-item-status' => 'publish'
'menu-item-parent-id' => $top_menu,
));
//Sub Sub menu item (first child)
$Second_child = wp_update_nav_menu_item($menu->term_id, 0, array(
'menu-item-title' => __('Second_Child'),
'menu-item-classes' => 'home',
'menu-item-url' => home_url( '/' ),
'menu-item-status' => 'publish'
'menu-item-parent-id' => $first_child,
));
你也可以用 menu-item-position 的程式碼來設定位置,我認為它是這樣做的:
-
第一項 – ‘menu-item-position’ => 1
-
第一項第一個孩子 – ‘menu-item-position’ => 1
-
第一項第二個孩子 – ‘menu-item-position’ => 1
-
第一項第二個孩子第一個孩子 – ‘menu-item-position’ => 1
-
-
-
第二項 – ‘menu-item-position’ => 2
-
第 3 項 – ‘menu-item-position’ => 3
-
第 4 項 – ‘menu-item-position’ => 4
次佳解決方案
你的原始程式碼是非常接近的錢,我認真地認為這個長期的解決方案 @Bainternet(沒有進攻) 是過度的,所以看看這個:
function new_nav_menu_items($items, $args) {
if( $args->theme_location == 'primary' ){
$homelink = '<li class="home"><a href="http://'%20.%20home_url(%20'/'%20)%20.%20'">' . __('Home') . '</a></li>';
$items = $homelink . $items;
}
return $items;
}
add_filter( 'wp_nav_menu_items', 'new_nav_menu_items', 10, 2 );
您唯一的問題是,在函式檢查正確的選單後,您沒有返回 $項,並且您缺少進行檢查 ($ args) 所需的第二個回撥引數。
參考文獻
注:本文內容整合自 Google/Baidu/Bing 輔助翻譯的英文資料結果。如果您對結果不滿意,可以加入我們改善翻譯效果:薇曉朵技術論壇。