我正在尝试生成可用优惠券列表并使用短代码显示它们。我希望使用 SQL 而不是“-1
”生成列表,因为根据我的理解,这对数据库来说更重。
我得到的错误是这样的:Notice: Array to string conversion
add_shortcode('ac', 'coupon_list' );
function coupon_list() {
// array for coupons, was hoping for a sql query instead but don't know how
$args = array(
'posts_per_page' => -1,
'orderby' => 'title',
'order' => 'asc',
'post_type' => 'shop_coupon',
'post_status' => 'publish',
);
$coupons = get_posts( $args );
$coupon_names = array();
foreach ( $coupons as $coupon ) {
$coupon_name = $coupon->post_title;
array_push( $coupon_names, $coupon_name );
}
// display all available coupons on product page
echo $coupon_names;
}
最佳答案
您的代码中有 2 个错误:您正在尝试使用 echo
显示数组,并且在使用简码函数时需要返回 (未回应)。
以下函数(短代码)将使用简单的 SQL 查询显示所有可用优惠券代码的逗号分隔字符串:
add_shortcode('ac', 'available_coupon_codes' );
function available_coupon_codes() {
global $wpdb;
// Get an array of all existing coupon codes
$coupon_codes = $wpdb->get_col("SELECT post_name FROM $wpdb->posts WHERE post_type = 'shop_coupon' AND post_status = 'publish' ORDER BY post_name ASC");
// Display available coupon codes
return implode(', ', $coupon_codes) ; // always use return in a shortcode
}
代码进入事件子主题(或事件主题)的 functions.php 文件。经过测试并有效。
用法:
1) 在帖子、自定义帖子或页面的 WordPress 文本编辑器中:
[ac]
2) 在 php 文件或模板上:
echo available_coupon_codes();
或
echo do_shortcode('[ac]');
使用 WP_Query(就像在您的代码中一样):
add_shortcode('ac', 'coupon_list' );
function coupon_list() {
$coupon_posts = get_posts( array(
'posts_per_page' => -1,
'orderby' => 'name',
'order' => 'asc',
'post_type' => 'shop_coupon',
'post_status' => 'publish',
) );
$coupon_codes = []; // Initializing
foreach( $coupon_posts as $coupon_post) {
$coupon_codes[] = $coupon_post->post_name;
}
// Display available coupon codes
return implode(', ', $coupon_codes) ; // always use return in a shortcode
}
代码进入事件子主题(或事件主题)的 functions.php 文件。经过测试并有效。
与第一个函数的用法相同
关于php - 创建可用的 WooCommerce 优惠券代码列表并使用简码在任何地方显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62230388/