DUX 主题,这个主题看起来很不错,但是缩略图的设置很简单:如果设置了“特色图像”,就以“特色图像”作为缩略图;如果没有设置“特色图像”,则显示一幅默认的图片。经过研究,我最终实现了DUX 主题随机缩略图的显示:如果设置了“特色图像”,就以“特色图像”作为缩略图;如果没有设置“特色图像”,则自动调取文章内第一幅图片作为缩略图;如果文章内没有图片,则随机显示一幅图片。
具体实现方法如下(以 DUX 1.3 版本为例):
首先修改 inc/fn.php,打开 fn.php 文件,找到第 463 行,将以下内容:
$html = sprintf('
', get_stylesheet_directory_uri() . '/img/thumbnail.png', $class);
修改为:
$random = mt_rand(1, 20);
$html = sprintf('
', get_stylesheet_directory_uri() . '/img/random/'.$random.'.jpg', $class);
接下来,我们在主题的 img 下建立一个文件夹 random,复制进 20 张图片,并重命名为 1.jpg、2.jpg……20.jpg,这样,DUX 主题就实现了自动显示随机缩略图的功能,如果文章没有设置“特色图像”,将随机显示一幅图片。
下面我来实现自动调取第一幅图片,在主题的 functions.php 文件中加入如下代码:
function autoset_featured() {
global $post;
$already_has_thumb = has_post_thumbnail($post->ID);
if (!$already_has_thumb) {
$attached_image = get_children( "post_parent=$post->ID&post_type=attachment&post_mime_type=image&numberposts=1" );
if ($attached_image) {
foreach ($attached_image as $attachment_id => $attachment) {
set_post_thumbnail($post->ID, $attachment_id);
}
}
}
} //end function
add_action('the_post', 'autoset_featured');
add_action('save_post', 'autoset_featured');
add_action('draft_to_publish', 'autoset_featured');
add_action('new_to_publish', 'autoset_featured');
add_action('pending_to_publish', 'autoset_featured');
add_action('future_to_publish', 'autoset_featured');
这样,DUX 主题就修改完了,保存即可看到效果。
声明:1、本博客不从事任何主机及服务器租赁业务,不参与任何交易,也绝非中介。博客内容仅记录博主个人感兴趣的服务器测评结果及一些服务器相关的优惠活动,信息均摘自网络或来自服务商主动提供;所以对本博客提及的内容不作直接、间接、法定、约定的保证,博客内容也不具备任何参考价值及引导作用,访问者需自行甄别。2、访问本博客请务必遵守有关互联网的相关法律、规定与规则;不能利用本博客所提及的内容从事任何违法、违规操作;否则造成的一切后果由访问者自行承担。3、未成年人及不能独立承担法律责任的个人及群体请勿访问本博客。4、一旦您访问本博客,即表示您已经知晓并接受了以上声明通告。
你可能也喜欢
- ♥ DUX 主题 7.3 版本更新:重做客服功能、新增注册白名单、标签云随机等多项超实用功能07/14
- ♥ ThemeBetter:元旦年度大放价|全场 7 折抄底价,建站好物囤起来01/01
- ♥ DUX 主题 7.2 版本更新:新增幻灯片小工具、全屏页面模版、头像服务器自定义以及多项功能更新04/26
- ♥ themebetter 主题:618 年度大放价,全场 7 折特惠,主题最高直降 320 元08/02
- ♥ WordPress 主题 2020 年 11.11 大放价,DUX 主题/XIU 主题/D8 主题全场 6.0 折,终身授权 138 元起11/04
- ♥ DUX 主题 7.8 版本更新:新增分类置顶文章、代码区域复制、相关文章缓存等 15 项功能与调整05/16







