ホームページ >CMS チュートリアル >&#&プレス >WooCommerce カテゴリ、サブカテゴリ、および製品を表示するための個別のリスト

WooCommerce カテゴリ、サブカテゴリ、および製品を表示するための個別のリスト

PHPz
PHPzオリジナル
2023-09-02 17:53:051463ブラウズ

用于显示 WooCommerce 类别、子类别和产品的单独列表

WooCommerce には、アーカイブ ページに表示できる内容に関するいくつかのオプションがあります:

    ###製品###
  • カテゴリ (メイン ストア ページ上) またはサブカテゴリ (カテゴリ ページ上)
  • 製品とカテゴリ
  • ストアを構築するとき、私は通常 3 番目のオプション、製品とカテゴリ/サブカテゴリを選択します。これは、私のストアへの訪問者がホームページから直接製品を選択したり、製品カテゴリのプロフィールをクリックして検索を絞り込んだりできることを意味します。

ただし、このアプローチには欠点があります。カテゴリとサブカテゴリが一緒に表示され、両者が分離されません。そのため、商品画像とサイズが異なる場合、レイアウトが少し混乱して見える可能性があります。画像のサイズが同じであっても、アーカイブ ページの行にカテゴリと商品の両方が含まれている場合、カテゴリの [カートに追加] ボタンがない場合、すべての要素のサイズが同じではないため、行が乱雑に見えます。

このチュートリアルでは、商品を表示する前に、カテゴリーを別のリストに表示する方法を説明します。

これを行うには、4 つの手順に従います:

WooCommerce がアーカイブ ページにカテゴリとサブカテゴリを出力するために使用するコードを決定します。
  1. コードのプラグインを作成します。
  2. 製品リストの前にカテゴリまたはサブカテゴリを挿入する関数を作成します。
  3. 出力スタイルを設定します。
  4. ただし、始める前に、WooCommerce をインストールし、いくつかの製品を追加し、製品カテゴリとサブカテゴリを設定する必要があります。
###あなたは何が必要ですか###

続行するには、次のものが必要です:

WordPressの開発インストール

コードエディタ
  • WooCommerce がインストールされ有効化されました
  • 製品を追加しました - WooCommerce に付属するダミーの製品データをインポートしました。これを行う方法の詳細については、このガイドを参照してください。
  • WooCommerce 互換テーマがアクティブになりました - Storefront を使用しています
  • 始める前に: デフォルトのオプション
  • WooCommerce がデフォルトで提供するものを見てみましょう。

WooCommerce のダミー データには画像が含まれていないため、製品カテゴリとサブカテゴリにいくつかの画像を追加することから始めました。スクリーンショットに示すように、各カテゴリまたはサブカテゴリから 1 つの製品の画像を使用しただけです:

それでは、WooCommerce がアーカイブ ページに製品カテゴリと製品をどのように表示するかを見てみましょう。

用于显示 WooCommerce 类别、子类别和产品的单独列表まだカスタマイザーを開いていない場合は、

WooCommerce

タブを選択し、

製品カタログ

をクリックします。

ストア ページの表示 用于显示 WooCommerce 类别、子类别和产品的单独列表

カテゴリと製品の表示

を選択し、次に カテゴリの表示 サブカテゴリと製品の表示 Strong> を選択します。

[

公開 用于显示 WooCommerce 类别、子类别和产品的单独列表] をクリックして変更を保存し、Web サイトのストア ページにアクセスします。私のものは次のようになります:

4 つのカテゴリと 3 つの並べた画像のグリッドがあるため、最初の 2 つの製品はカテゴリの 1 つと並べて表示されます。

用于显示 WooCommerce 类别、子类别和产品的单独列表 カテゴリとサブカテゴリをより目立つようにして、製品リストとは別に単純に表示したいと考えています。それでは、これをやってみましょう。

WooCommerce がアーカイブ内のカテゴリと製品を出力するために使用するコードを識別します

最初のステップは、WooCommerce がカテゴリとサブカテゴリを出力する方法を決定することです。それでは、WooCommerce のソース コードを詳しく調べて、関連する関数を見つけてみましょう。

WooCommerce がアーカイブ ページを表示するために使用するファイルは

archive-product.php

で、テンプレート フォルダーにあります。

そのファイルには、カテゴリと製品を出力するコードがあります: リーリー したがって、商品を出力するループを実行する前にカテゴリまたはサブカテゴリを出力する

woocommerce_product_subcategories()

関数があります。

この関数はプラグイン可能です。つまり、テーマ内でオーバーライドできます。残念ながら、WooCommerce には項目をクリアするための組み込みスタイルがあり、デフォルトで表示される行の先頭に表示されるため、これは完全には機能しません。 <p>因此,我们将关闭存档页面上类别和子类别的显示,以便仅显示产品。然后,我们将创建一个输出产品类别或子类别的新函数,并将其挂钩到 <code>woocommerce_before_shop_loop 操作,确保我们使用高优先级,以便它在已经挂钩到该操作的函数之后触发。 p>

注意:由于 WooCommerce 向每个第三个产品列表添加了清除内容,因此我们无法使用 woocommerce_product_subcategories() 函数或其编辑版本来显示类别。这是因为即使我们使用此功能单独显示类别,它也会清除列出的第三、第六(等等)类别或产品。我们可以尝试覆盖它,但编写我们自己的函数更简单。

所以让我们创建一个插件来实现这一点。

创建插件

在您的wp-content/plugins目录中,创建一个新文件夹并为其指定一个唯一的名称。我将我的命名为tutsplus-separate-products-categories-in-archives。在其中创建一个新文件,同样具有唯一的名称。我使用相同的名称:tutsplus-separate-products-categories-in-archives.php

打开您的文件并向其中添加以下代码:

<?php
/**
* Plugin Name: Tutsplus display WooCommerce products and categories/subcategories separately in archive pages
* Plugin URI: https://code.tutsplus.com/tutorials/woocommerce-display-product-categories-subcategories-and-products-in-two-separate-lists--cms-25479
* Description: Display products and categories / subcategories as two separate lists in product archive pages
* Version: 1.0
* Author: Rachel McCollin
* Author URI: https://rachelmccollin.co.uk
*
*
*/

您可能想要编辑作者详细信息,因为这是您正在编写的插件。保存您的文件并通过 WordPress 管理员激活插件。

编写我们的函数

现在让我们编写函数。但在开始之前,请关闭管理屏幕上的类别列表。打开定制器,单击 WooCommerce 选项,然后单击产品目录。对于每个商店页面显示默认类别显示选项,选择显示产品。点击发布保存您的更改。

您的商店页面现在看起来像这样:

用于显示 WooCommerce 类别、子类别和产品的单独列表

在您的插件文件中,添加以下内容:

function tutsplus_product_subcategories( $args = array() ) {

}

add_action( 'woocommerce_before_shop_loop', 'tutsplus_product_subcategories', 50 );

现在,在函数中添加以下代码:

$parentid = get_queried_object_id();

$args = array(
    'parent' => $parentid
);

$terms = get_terms( 'product_cat', $args );

if ( $terms ) {
    echo '<ul class="product-cats">';

    foreach ( $terms as $term ) {
        echo '<li class="category">';                 
            woocommerce_subcategory_thumbnail( $term );
            echo '<h2>';
                echo '<a href="' .  esc_url( get_term_link( $term ) ) . '" class="' . $term->slug . '">';
                    echo $term->name;
                echo '</a>';
            echo '</h2>';
        echo '</li>';
    }

    echo '</ul>';
}

让我们看一下该函数的作用:

  • 它标识当前查询的对象并将其 ID 定义为 $parentid
  • 它使用 get_terms() 来识别以当前查询项作为其父项的术语。如果这是商店主页面,则会返回顶级类别;如果这是一个类别存档,它将返回子类别。
  • 然后,它会检查是否存在任何术语,然后打开 for every 循环和 ul 元素。
  • 对于每个术语,它都会创建一个 li 元素,然后使用 woocommerce_subcategory_thumbnail() 输出类别图像,后跟其存档链接中的类别名称。

现在保存您的文件并刷新主商店页面。我的看起来像这样:

用于显示 WooCommerce 类别、子类别和产品的单独列表

类别已显示,但需要一些样式。接下来我们就这样做。

设置类别列表的样式

为了添加样式,我们的插件中需要一个样式表,我们需要将其排队。

在您的插件文件夹中,创建一个名为 css 的文件夹,并在其中创建一个名为 style.css 的文件。

现在,在您的插件文件中,将其添加到您已创建的函数上方:

function tutsplus_product_cats_css() {
    /* register the stylesheet */
    wp_register_style( 'tutsplus_product_cats_css', plugins_url( 'css/style.css', __FILE__ ) );
    /* enqueue the stylesheet */
    wp_enqueue_style( 'tutsplus_product_cats_css' );
}

add_action( 'wp_enqueue_scripts', 'tutsplus_product_cats_css' );

这会正确地将您刚刚创建的样式表排入队列。

现在打开样式表并添加以下代码。 WooCommerce 使用移动优先样式,因此我们也将使用它。

ul.product-cats {
    margin-left: 0;
}

ul.product-cats li {
    list-style: none;
    margin-left: 0;
    margin-bottom: 4.236em;
    text-align: center;
    position: relative;
}

ul.product-cats li img {
    margin: 0 auto; 
}

@media screen and (min-width:768px) {

    ul.product-cats li {
        width: 29.4117647059%;
        float: left;
        margin-right: 5.8823529412%;
    }

    ul.product-cats li:nth-of-type(3) {
        margin-right: 0;
    }

}

我已从 WooCommerce 使用的样式中复制了准确​​的宽度和边距。

现在再次检查您的主商店页面。这是我的:

用于显示 WooCommerce 类别、子类别和产品的单独列表

这是服装类别存档:

用于显示 WooCommerce 类别、子类别和产品的单独列表

这是它在较小屏幕上的外观:

用于显示 WooCommerce 类别、子类别和产品的单独列表

摘要

产品类别是 WooCommerce 的一大功能,但它们的显示方式并不总是理想。在本教程中,您学习了如何创建一个插件,该插件可以与产品列表分开输出产品类别或子类别,然后设置类别列表的样式。

您可以使用此代码在页面其他位置(例如,产品下方)输出类别或子类别列表,方法是将函数挂钩到 WooCommerce 模板文件中的不同操作挂钩。

現在拡張したいストアを運営している場合、または他の WooCommerce 関連のプラグインを探している場合は、CodeCanyon でどのようなプラグインが利用できるかを自由にチェックしてください。

CodeCanyon 2021 年のベスト WooCommerce プラグイン

CodeCanyon は、市場で最も柔軟で機能が豊富な WooCommerce WordPress プラグインを提供し、ユーザーが使い慣れたオンライン ストアに別次元の機能を追加します。

カスタム フィールドとアップロードの実装、複数の通貨の表示、またはメンバーシップの提供が必要な場合でも、CodeCanyon で利用できるさまざまな WooCommerce プラグインは、これらのタスクの達成に役立ちます。

利用可能なすべての高品質 WooCommerce プラグインに加えて、CodeCanyon には Web サイトの強化に役立つ他の高品質 WordPress プラグインが何千もあります。広範なプラグイン ライブラリを参照すると、フォーラム、メディア、SEO プラグインなど、あらゆる種類のプラグインのプラグインが見つかります。

CodeCanyon の高品質 WordPress プラグインの膨大なライブラリを今すぐ活用してください!

用于显示 WooCommerce 类别、子类别和产品的单独列表

自分に合った WooCommerce プラグインを選択するのにサポートが必要な場合は、Envato Tuts の他の投稿をチェックしてください:

以上がWooCommerce カテゴリ、サブカテゴリ、および製品を表示するための個別のリストの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。