3 php wordpress shortcode coupon woocommerce
我正在尝试生成可用优惠券列表并使用短代码显示它们。我希望使用 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;
}
Run Code Online (Sandbox Code Playgroud)
您的代码中有 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
}
Run Code Online (Sandbox Code Playgroud)
代码位于活动子主题(或活动主题)的functions.php 文件中。经过测试并有效。
用法:
1) 在帖子、自定义帖子或页面的 WordPress 文本编辑器中:
[ac]
Run Code Online (Sandbox Code Playgroud)
2) 在 php 文件或模板上:
echo available_coupon_codes();
Run Code Online (Sandbox Code Playgroud)
或者
echo do_shortcode('[ac]');
Run Code Online (Sandbox Code Playgroud)
使用 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
}
Run Code Online (Sandbox Code Playgroud)
代码位于活动子主题(或活动主题)的functions.php 文件中。经过测试并有效。
与第一个函数的用法相同