sql >> データベース >  >> RDS >> Mysql

WooCommerceの一部のテンプレートでカテゴリオブジェクトを取得できません

    get_category()は使用できません または get_term() どこでもIDで直接。 ここに記載されている引数をさらに使用する必要があります (以下の例を参照) 。テンプレートについては、表示されている商品にもよると思います(このカテゴリまたはサブカテゴリがある場合)。

    その他の便利なWordPress関数:
    カテゴリIDに基づいてカテゴリ名を取得するには、 get_the_category_by_ID()
    カテゴリ名でIDを取得することもできます get_cat_ID( 'cat_name' )を使用します

    get_category()を使用して製品カテゴリとサブカテゴリを一覧表示する (例)

    これは、<に基づく関数の例です。強い>このスレッド 、すべての製品カテゴリとサブカテゴリが一覧表示されます (どこでも)

    function products_cats_subcats(){
        $taxonomy     = 'product_cat';
        $orderby      = 'name';
        $show_count   = 0;      // 1 for yes, 0 for no
        $pad_counts   = 0;      // 1 for yes, 0 for no
        $hierarchical = 1;      // 1 for yes, 0 for no
        $title        = '';
        $empty        = 0;
    
        $args = array(
            'taxonomy'     => $taxonomy,
            'orderby'      => $orderby,
            'show_count'   => $show_count,
            'pad_counts'   => $pad_counts,
            'hierarchical' => $hierarchical,
            'title_li'     => $title,
            'hide_empty'   => $empty
        );
        $all_categories = get_categories( $args );
        echo '<ul>';
        foreach ($all_categories as $cat) {
            if($cat->category_parent == 0) {
                $category_id = $cat->term_id;
                echo '<li><a href="'. get_term_link($cat->slug, 'product_cat') .'">'. $cat->name .'</a></li>';
    
                $args2 = array(
                    'taxonomy'     => $taxonomy,
                    'child_of'     => 0,
                    'parent'       => $category_id,
                    'orderby'      => $orderby,
                    'show_count'   => $show_count,
                    'pad_counts'   => $pad_counts,
                    'hierarchical' => $hierarchical,
                    'title_li'     => $title,
                    'hide_empty'   => $empty
                );
                $sub_cats = get_categories( $args2 );
                echo '<ol>';
                if($sub_cats) {
                    foreach($sub_cats as $sub_category) {
                        echo  '<li><a href="'. get_term_link($sub_category->slug, 'product_cat') .'">' . $sub_category->name .'</a></li>';
                    }
                }
                echo '</ol>';
            }
        }
        echo '</ul>';
    }
    

    使用するには、次の場所に配置します。 <?php products_cats_subcats() ;?>

    これにより、すべてのカテゴリとサブカテゴリが名前の順に階層的に表示されます。 、各カテゴリまたはサブカテゴリに対応するリンクがあります。

    そうすれば、ニーズに合わせて独自の関数を作成できるようになります…

    参照:




    1. Postgresでデータを挿入して外部キーを設定する

    2. MySQLはinnodbテーブルの行数を取得します

    3. SQL Server(T-SQL)のプロファイル内のデータベースメールアカウントのシーケンス番号を変更する方法

    4. 続編モデルに外部キーを挿入する方法