Wordpress 数据库查询和输出为 HTML 列表

Wordpress Database query and Output as HTML list

我正在尝试让 PHP 代码工作,以便在 Wordpress 数据库 table 中进行数据库查询。结果(一个特定列的所有不同值)应放在 HTML 列表中。我希望能够将输出放在我的内容中的任何位置,因此应该可以通过短代码访问它。

这是我到目前为止得到的。此代码不会在 wordpress 或控制台中产生任何错误,但它也无法解决问题……没有任何东西出现在所需的位置。

class my_Shortcode {

    var $echo;

    function __construct() {
        add_shortcode( 'my_plugin', array( $this, 'shortcode' ) );
    }    

    function shortcode( $atts ) {
        global $wpdb;

        $table = isset( $atts['table'] ) ? $atts['table'] : false;
        $column = isset( $atts['column'] ) ? $atts['column'] : false;
        $listDisplay = isset( $atts['listDisplay'] ) ? $atts['listDisplay'] : false;

        if ( $listDisplay == true ) {
            if ( false != $table && false != $column ) {
                $this->echo = "";
                $results = $wpdb->get_results(
                    prepare('SELECT DISTINCT ' . $column . ' FROM ' . $table)
                );
                $this->echo .= "<div class=\"list\"><ul>";

                foreach ($results as $result) {
                    $this->echo .= "<li>$result</li>\n"; 
                }
                $this->echo .= "</ul></div>";
                return $this->echo;
            }
        }
    }
}

我很高兴收到任何建议!

你想要这样吗?

<?php
    echo do_shortcode("[my_plugin table='wp_posts' column=id]");
?>





class my_Shortcode {

    var $echo;

    function __construct() {
    add_shortcode( 'my_plugin', array( $this, 'shortcode' ) );
    }    

    function shortcode( $atts ) {
    global $wpdb;

    $table = isset( $atts['table'] ) ? $atts['table'] : false;
    $column = isset( $atts['column'] ) ? $atts['column'] : false;
    $listDisplay = isset( $atts['listDisplay'] ) ? $atts['listDisplay'] : true;

    if ( $listDisplay == true ) {
        if ( false != $table && false != $column ) {
        $this->echo = "";

        $results = $wpdb->get_results("SELECT DISTINCT  $column  FROM  $table ",ARRAY_A);


        $this->echo .= "<div class=\"list\"><ul>";

        foreach ($results as  $key => $result) {
            $keys = array_keys( $result);                   
            $this->echo .= '<li>'.$result[ $keys[0] ].'</li>\n'; 
        }
        $this->echo .= "</ul></div>";
        return $this->echo;
        }
    }
    }
}

$test = new my_Shortcode();