【问题标题】:Wordpress Database query and Output as HTML listWordpress 数据库查询和输出为 HTML 列表
【发布时间】:2017-08-14 13:06:54
【问题描述】:

我正在尝试让 PHP 代码工作,以便在 Wordpress 数据库表中进行数据库查询。结果(一个特定列的所有不同值)应放在 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 sql wordpress shortcode


    【解决方案1】:

    你想要这个吗?

    <?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();
    

    【讨论】:

      猜你喜欢
      • 2021-10-08
      • 2015-11-26
      • 2022-12-11
      • 1970-01-01
      • 2014-08-25
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2022-07-06
      相关资源
      最近更新 更多