Почему мой html, возвращаемый шорткодом, не выполняется как html? - PullRequest
0 голосов
/ 25 мая 2018

Привет, я довольно новичок в php и начал возиться с шорткодом.Я создал быстрый шорткод, который возвращает строку, содержащую HTML.Я ожидал, что он будет выполнен браузером.Почти все это выполняется должным образом, за исключением ссылки, которая на самом деле печатается как

<a href="#" target="_blank">Example</a>

Вот мой шорткод, который я написал

            add_shortcode('booklist_jumbo','generate_booklist_jumbo');
            //[booklist_jumbo]
            function generate_booklist_jumbo($atts) 
            {
                $a = shortcode_atts( array(
                'category' => 'Upcoming',
                'name' => '',
                'list_order' => 'DESC'
                ), $atts );

                $bookOrder = $a[book_order];
                $listOrder = $a[list_order];

                if($a[name] !== '') {
                    $name = $a[name];
                    $second_db = new wpdb(DB_USER, DB_PASSWORD, "saic3_LibraryIndex", DB_HOST);
                    $query = "SELECT * FROM `LibraryList` WHERE `list_name` = %s ORDER BY date_created $listOrder LIMIT 1";
                    $booklist = $second_db->get_results( $second_db->prepare( $query, $name) );
                }
                else if($a[category] !== "") {
                    $cat = $a[category];
                    $second_db = new wpdb(DB_USER, DB_PASSWORD, "saic3_LibraryIndex", DB_HOST);
                    $query = "SELECT ll.* FROM LibraryListCategory llc INNER JOIN LibraryListCategoryList llcl ON llc.category_id = llcl.fk_category_id INNER JOIN LibraryList ll ON llcl.fk_list_id = ll.list_id WHERE llc.name= %s ORDER BY ll.date_created $listOrder LIMIT 1";
                    $booklist = $second_db->get_results( $second_db->prepare($query, $cat) );
                }
                if ($booklist!=null) {
                        $booklist[0]->list_name = stripslashes($booklist[0]->list_name);
                        $code = strval($booklist[0]->list_type_code);
                        $msg = stripslashes($booklist[0]->banner_msg);
                        $msg = str_replace("\\n", "<br>", $msg);
                        switch($code) {
                            case "1": $link = "/booklist-details/".$booklist[0]->fk_list_id; break;
                            case "2": $link = "/booklist-dvd-details/".$booklist[0]->fk_list_id; break;
                            case "3": $link = "/booklist-audio-details/".$booklist[0]->fk_list_id; break;
                        }
                        $content = '<div class="bootstrap-container"><div class="row"><div class="col-md-12"><div class="jumbotron container-fluid" style="height: 600px; width: 100%; background: url('.$booklist[0]->image_url.') no-repeat center center; background-size: cover;">';
                        $content.= '<a href="'.$link.'" target="_blank" ><h2 class="book-feat-title center-block">'.$booklist[0]->list_name.'</h2></a><p class="book-feat-msg">'.$msg.'</p>';    
                        $content.= '</div></div></div></div>';
                    }
                else {
                    $content="<h4>no booklist records</h4>";
                }

                $second_db->close();
                return $content;

            }

Все работает, как ожидалось, за исключением сообщения баннераэто завернуто в теге ap ... Я пытался найти что-то похожее, но не могу найти ничего.Я предполагаю, что это как-то связано с тем, что он считается строкой, а не HTML, но я не уверен, как это исправить.

enter image description here

1 Ответ

0 голосов
/ 25 мая 2018

Пожалуйста, добавьте еще одну строку для $msg

$msg = str_replace("\\n", "<br>", $msg);
$msg = add_filter( 'the_content', $msg );
...