반응형
woocommerce에 페이지당 제품 드롭다운 추가
플러그인을 사용하지 않고 우커머스 스토어 프론트 차일드 테마에 '페이지당 제품' 드롭다운을 추가하려고 합니다.제 기능에 아래 코드를 추가합니다.php 소스
add_action( 'woocommerce_before_shop_loop', 'ps_selectbox', 25 );
function ps_selectbox() {
$per_page = filter_input(INPUT_GET, 'perpage', FILTER_SANITIZE_NUMBER_INT);
echo '<div class="woocommerce-perpage">';
echo '<span>Per Page: </span>';
echo '<select onchange="if (this.value) window.location.href=this.value">';
$orderby_options = array(
'8' => '8',
'16' => '16',
'32' => '32',
'64' => '64'
);
foreach( $orderby_options as $value => $label ) {
echo "<option ".selected( $per_page, $value )." value='?perpage=$value'>$label</option>";
}
echo '</select>';
echo '</div>';
}
add_action( 'pre_get_posts', 'ps_pre_get_products_query' );
function ps_pre_get_products_query( $query ) {
$per_page = filter_input(INPUT_GET, 'perpage', FILTER_SANITIZE_NUMBER_INT);
if( $query->is_main_query() && !is_admin() && is_post_type_archive( 'product' ) ) {
$query->set( 'posts_per_page', $per_page );
}
}
이렇게 하면 드롭다운 상자에 표시되지만 선택한 옵션은 테마의 첫 페이지로 돌아갑니다.
누가 나를 도와줄 수 있나요?
아래 코드를 함수에 추가할 수 있습니다.php 파일.참조:
첫 번째 단계는 상점 보관 페이지에 선택 상자를 표시하는 것입니다.일부 기본 php를 사용하면 wocommerce_before_shop_loop hook을 통해 선택 상자를 반향할 수 있습니다.
add_action( 'woocommerce_before_shop_loop', 'ps_selectbox', 25 );
function ps_selectbox() {
$per_page = filter_input(INPUT_GET, 'perpage', FILTER_SANITIZE_NUMBER_INT);
echo '<div class="woocommerce-perpage">';
echo '<span>Per Page: </span>';
echo '<select onchange="if (this.value) window.location.href=this.value">';
$orderby_options = array(
'8' => '8',
'16' => '16',
'32' => '32',
'64' => '64'
);
foreach( $orderby_options as $value => $label ) {
echo "<option ".selected( $per_page, $value )." value='?perpage=$value'>$label</option>";
}
echo '</select>';
echo '</div>';
}
일부 인라인 jQuery가 추가되어 선택란이 변경될 때마다 "페이지당 제품" 변수가 브라우저로 전송됩니다.
filter_input() 함수는 이 경우 보여줄 제품의 개수인 외부 변수를 가져와 검사합니다.
이제 "get" 방법을 통해 페이지 당 제품 수가 많은 pre_get_posts 후크를 실행할 수 있습니다.
add_action( 'pre_get_posts', 'ps_pre_get_products_query' );
function ps_pre_get_products_query( $query ) {
$per_page = filter_input(INPUT_GET, 'perpage', FILTER_SANITIZE_NUMBER_INT);
if( $query->is_main_query() && !is_admin() && is_post_type_archive( 'product' ) ){
$query->set( 'posts_per_page', $per_page );
}
}
이 방법은 가장 간단한 방법으로 WooCommerce 스토어에 "페이지당 제품" 드롭다운을 추가할 수 있으며, ajax 방법을 사용할 수도 있습니다.
여기서 가져온 다음 코드를 사용하고 있습니다.
// Lets create the function to house our form
remove_action( 'woocommerce_before_shop_loop', 'woocommerce_catalog_ordering', 30 );
function woocommerce_catalog_page_ordering() {
?>
<?php echo '<span class="itemsorder">Items Per Page:' ?>
<form action="" method="POST" name="results" class="woocommerce-ordering">
<select name="woocommerce-sort-by-columns" id="woocommerce-sort-by-columns" class="sortby" onchange="this.form.submit()">
<?php
//Get products on page reload
if (isset($_POST['woocommerce-sort-by-columns']) && (($_COOKIE['shop_pageResults'] <> $_POST['woocommerce-sort-by-columns']))) {
$numberOfProductsPerPage = $_POST['woocommerce-sort-by-columns'];
} else {
$numberOfProductsPerPage = $_COOKIE['shop_pageResults'];
}
// This is where you can change the amounts per page that the user will use feel free to change the numbers and text as you want, in my case we had 4 products per row so I chose to have multiples of four for the user to select.
$shopCatalog_orderby = apply_filters('woocommerce_sortby_page', array(
//Add as many of these as you like, -1 shows all products per page
// '' => __('Results per page', 'woocommerce'),
'20' => __('20', 'woocommerce'),
'-1' => __('All', 'woocommerce'),
));
foreach ( $shopCatalog_orderby as $sort_id => $sort_name )
echo '<option value="' . $sort_id . '" ' . selected( $numberOfProductsPerPage, $sort_id, true ) . ' >' . $sort_name . '</option>';
?>
</select>
</form>
<?php echo ' </span>' ?>
<?php
}
// now we set our cookie if we need to
function dl_sort_by_page($count) {
if (isset($_COOKIE['shop_pageResults'])) { // if normal page load with cookie
$count = $_COOKIE['shop_pageResults'];
}
if (isset($_POST['woocommerce-sort-by-columns'])) { //if form submitted
setcookie('shop_pageResults', $_POST['woocommerce-sort-by-columns'], time()+1209600, '/', 'www.your-domain-goes-here.com', false); //this will fail if any part of page has been output- hope this works!
$count = $_POST['woocommerce-sort-by-columns'];
}
// else normal page load and no cookie
return $count;
}
add_filter('loop_shop_per_page','dl_sort_by_page');
add_action( 'woocommerce_before_shop_loop', 'woocommerce_catalog_page_ordering', 20 );
언급URL : https://stackoverflow.com/questions/42744586/adding-a-products-per-page-dropdown-to-woocommerce
반응형
'programing' 카테고리의 다른 글
C - 오류: 'a'의 저장 크기를 알 수 없습니다. (0) | 2023.10.08 |
---|---|
.NET과 함께 CouchDB 사용 (0) | 2023.10.08 |
선호 속성 안드로이드: 의존성의 반대를 하는 방법? (0) | 2023.10.03 |
웹 응용 프로그램(스프링 보안을 통해)에 로그인한 모든 사용자의 목록을 확인하려면 어떻게 해야 합니까? (0) | 2023.10.03 |
AngularJS UI 라우터:중첩된 명명된 뷰를 구성하는 방법은 무엇입니까? (0) | 2023.10.03 |