我可以修改'wc-template-functions.php'文件中的WooCommerce函数,还是应该坚持使用'functions.php'文件进行修改?

时间:2017-02-20 00:19:17

标签: php wordpress templates woocommerce hook-woocommerce

为什么将WooCommerce功能修改放在主题的'function.php'文件中是首选?加班,这会使文件相当大。我的理解是,通常更好的做法是拥有大量组织良好的小文件,而不是更少的大文件。

考虑到这一点,将'wc-template-functions.php'和'wc-templates-hooks.php'文件复制到主题中(同时保持其文件层次结构)并相应地修改这些文件有什么问题?

作为一个附带请求,从一个相对新手到WooCommerce平台,如果我能得到一个'是,那可行'或'不,我已经错过了一些东西'回应我对以下的理解WooCommerce;文件,钩子,动作和模板都与一个和其他

一起使用

我的理解:

  1. WooCommerce功能在'wc-template-functions.php'文件中注册。出于解释的目的,我想参考woocommerce_breadcrumb条目。
  2. WooCommerce然后使用'wc-templates-hooks.php'文件通过使用add_action('woocommerce_before_main_content','woocommerce_breadcrumb', 20, 0 );这样的典型条目来调用已注册的函数。这只是指示在{{1}内调用woocommerce_breadcrumb }} hook。
  3. 然后,WooCommerce可以在必要时放置woocommerce_before_main_content来输出上述内容。在这种情况下,在所有模板文件中。

2 个答案:

答案 0 :(得分:12)

你的1,2,3理解是正确的。

但是,文件wc-template-functions.phpwc-templates-hooks.php不会通过在主题中放置类似文件来覆盖,因此在主题中使用它们将无法执行任何操作。

当您想要更改特定内容时批量复制/覆盖文件也是一个坏主意(在我看来)。当客户的网站崩溃时,我不得不在整个WooCommerce模板文件夹中搜索,以找到需要维护的实际更改。

functions.php文件分成更小,更易于管理的文件没有任何问题。因此,您可以拥有一个woocommerce-functions.php文件名,无论您希望存储特定于WooCommerce的代码。

编辑以扩展一些想法

任何时候WooCommerce(或任何WordPress功能)都会向您展示这种模式:

if ( ! function_exists( 'some_function_name' ) ) {

    function some_function_name() {
        echo 'taco';
    }
}

你有一个可插拔的功能,你可以在你的主题function.php中定义它,而WooCommerce将使用你的some_function_name()版本。

但是,可插入函数在它们被挂钩的地方被挂钩,你无法通过在主题/插件中重新定义它们来移动它们。所以一个更强大的方法是从它的钩子中删除该函数,并添加回不同的钩子,或者添加自己的自定义函数,或者两者兼而有之。这是一个将自定义标题移动到价格之后的示例:

function kia_switch_loop_title(){
    remove_action( 'woocommerce_shop_loop_item_title', 'woocommerce_template_loop_product_title', 10 );
    add_action( 'woocommerce_after_shop_loop_item_title', 'kia_template_loop_product_title', 15 );
}
add_action( 'woocommerce_before_shop_loop_item', 'kia_switch_loop_title' );

function kia_template_loop_product_title() {
    echo '<h4 class="we-do-what-we-want">' . get_the_title() . '</h4>';
}

答案 1 :(得分:0)

一直在努力以相关的方式对相关产品进行分类,找到了解决方案。万一有人需要

function custom_remove_hook(){
    remove_action( 'woocommerce_after_single_product_summary', 'woocommerce_output_related_products', 20 );
    add_action( 'woocommerce_after_single_product_summary', 'custom_function_to_sort_related', 22 );
}
add_action( 'woocommerce_after_single_product_summary', 'custom_remove_hook' );

function custom_function_to_sort_related( $args = array() ) {
        global $product;

        if ( ! $product ) {
            return;
        }

        $defaults = array(
            'posts_per_page' => 4,
            'columns'        => 4,
            'orderby'        => 'price', // @codingStandardsIgnoreLine.
            'order'          => 'desc'
        );

        $args = wp_parse_args( $args, $defaults );

        // Get visible related products then sort them at random.
        $args['related_products'] = array_filter( array_map( 'wc_get_product', wc_get_related_products( $product->get_id(), $args['posts_per_page'], $product->get_upsell_ids() ) ), 'wc_products_array_filter_visible' );

        // Handle orderby.
        $args['related_products'] = wc_products_array_orderby( $args['related_products'], $args['orderby'], $args['order'] );

        // Set global loop values.
        wc_set_loop_prop( 'name', 'related' );
        wc_set_loop_prop( 'columns', apply_filters( 'woocommerce_related_products_columns', $args['columns'] ) );

        wc_get_template( 'single-product/related.php', $args );
    }