Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Nie można uzyskać obiektu kategorii w niektórych szablonach WooCommerce

Nie możesz użyć get_category() lub get_term() bezpośrednio z identyfikatorem wszędzie. Musisz użyć więcej argumentów wymienionych tutaj (patrz przykład poniżej) . W przypadku szablonów myślę, że zależy to również od wyświetlanych produktów (jeśli mają tę kategorię lub podkategorię).

Inne przydatne funkcje WordPress:
Aby pobrać nazwę kategorii na podstawie identyfikatora kategorii, musisz użyć get_the_category_by_ID() .
Możesz również pobrać identyfikator według nazwy kategorii i użyjesz get_cat_ID( 'cat_name' ) .

Wyświetlanie kategorii i podkategorii produktów za pomocą get_category() (przykład) :

Oto przykład funkcji opartej na ten wątek , który wyświetli listę wszystkich kategorii i podkategorii produktów (wszędzie) :

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>';
}

Aby go użyć, po prostu umieść go tam, gdzie chcesz:<?php products_cats_subcats() ;?>

Spowoduje to wyświetlenie wszystkich kategorii i podkategorii hierarchicznie uporządkowanych według Nazwy , z odpowiednim linkiem dla każdej kategorii lub podkategorii.

Teraz będziesz mógł tworzyć własne funkcje, zgodnie z własnymi potrzebami…

Odniesienie:




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Czy mogę porównać znacznik czasu MysQL z kolumnami daty i godziny? to jest złe?

  2. Konwertuj ciąg na obiekt Datetime w SQL

  3. Łącznik Mysql - problem z MultipleActiveResultSets

  4. Błąd podczas importowania zrzutu SQL do MySQL:Nieznana baza danych / Nie można utworzyć bazy danych

  5. Używanie local.js do przechowywania hasła sails-mysql