我正在尝试为我的博客制作一个 Wordpress 插件,用于扫描包含自定义字段
_videoembed
的帖子。我已经完成了所有工作并且可以正确激活,但是当我打开页面进行测试时收到 PHP 错误:
Fatal error: Call to a member function get_results() on a non-object in .../wp-content/plugins/youtubesubscription/videos.php on line 26.
有人对 PHP 有足够的了解来帮助我吗?这是我的插件代码(由于大小而粘贴在pastebin上): http://pastebin.com/uaEWjTn2
编辑1
插入
global $wpdb;
后我不再收到任何错误,但现在什么也没有显示。这是我更新的代码:http://pastebin.com/R2ZuEknY。请注意,此代码还包含自动 YouTube 缩略图,这些缩略图是从将 YouTube URL 修剪为 ID 的函数中获得的(链接)。
编辑2
让它工作起来,结果我需要做的就是插入“_videoembed”作为 wp_query 的“meta_key”参数。下面是我的工作代码:
<?php
$args = array(
'meta_key' => '_videoembed',
'post_status' => 'publish',
'posts_per_page' => '' . $number . '',
'order' => 'date'
);
query_posts( $args );
while ( have_posts() ) : the_post(); ?>
<?php
global $post;
$VIDEOID = ytvideoID($post->ID);
?>
<li onClick="window.location.href='<?php the_permalink(); ?>'">
<?php
global $post;
$videoId = ytvideoID($post->ID);
$videoInfo = parseVideoEntry($videoId);
echo '<a href="'.get_permalink().'">';
echo '<div class="image">';
echo '<img src="http://img.youtube.com/vi/'.$VIDEOID.'/default.jpg">';
echo '<div id="time" style="position:absolute;z-index:9;bottom:2px;right:2px;font-size:10px;color:#fff;background:#000;padding:0px 2px;-webkit-border-radius: 4px;-moz-border-radius: 4px;border-radius: 4px;opacity:0.75;">'.hms($videoInfo->length).'</div>';
echo '</div>';
echo '<h4>'.get_the_title().'</h4>';
echo '<div id="description">';
echo '<div id"views"><h3>'.number_format($videoInfo->viewCount).' Views</h3></div>';
echo '<div class="singleauthor"><h3>by '.$videoInfo->author.'</h3></div>';
echo '</div>';
echo '</a>';
?>
</li>
<?php endwhile;
// Reset Query
wp_reset_query();
?>
您可以使用元查询通过自定义字段获取帖子。
$args= array(
'category_name' => 'courses',
'orderby' => 'menu_order',
'order' => 'ASC',
'meta_query' => array(
array(
'key' => 'front_page',
'value' => 'yes',
'compare' => 'LIKE',
))
);
$the_query = new WP_Query( $args );
您必须添加
global $wpdb;
尝试更换
function mbrecentvids()
{ ?>
<?php
与
function mbrecentvids()
{
global $wpdb;
第 26 行似乎缺少一个分号。
我明白了:
$pageposts = $wpdb->get_results($querydetails, OBJECT_K)