通过自定义字段重新排序 WordPress 文章方法
作者:WDC 发布时间:2023-12-14 21:52:53
您想更改网站博客页面上 WordPress 文章的顺序吗?那么您就在正确的地方学习此功能并更改文章的顺序。因此,在本文中,我将向您展示如何通过自定义字段更改文章的顺序。
WordPress 中文章的默认顺序基于发布日期,并按时间倒序显示。这意味着它将在顶部显示最新的文章。
通过为 WordPress 添加自定义字段,您可以根据该自定义字段更改顺序。
我将在下面的分步指南中解释如何创建自定义字段并更改博客页面上文章的顺序。
按自定义字段排序 WordPress 文章
让我们开始在帖子中创建一个自定义字段,并使用文章 ID 保存值并显示它们。
在发布元框中创建自定义字段
我们将在编辑文章页面右侧边栏的发布元框中创建一个数字自定义字段。字段值将保存在 post meta 表中,我们稍后将使用它来更改文章顺序。
有关发布元框中的自定义字段,请参阅下面的代码。
add_action('post_submitbox_misc_actions', 'add_publish_meta_custom_field');
function add_publish_meta_custom_field($post_obj) {
global $post;
$post_type = 'post';
$value = get_post_meta($post_obj->ID, 'post_order', true);
$val = ($value) ? $value : "0";
if($post_type==$post->post_type) {
echo '<div class="misc-pub-section misc-pub-section-last">'
.'<label>Post Order <input name="post_order" type="number" step="1" min="0" id="post_order" value="'.$val.'" class="small-text"></label>'
.'</div>';
}
}
以上将在发布元框中创建自定义字段,您将看到如下图所示的字段。
发布元框中的自定义字段
保存自定义字段的值
现在,我们必须保存Post Order字段的值。所以我们将save_post
在保存文章之前运行动作钩子,并update_post_meta()
用于保存相应文章的字段值。
update_post_meta()
操作将值与文章 ID 一起保存在wp_postmeta表中。
好的。请参阅代码以保存该自定义字段的值。
add_action( 'save_post', 'save_publish_meta_custom_field', 10 , 3);
function save_publish_meta_custom_field($post_id, $post, $update) {
$post_type = 'post';
if ( $post_type != $post->post_type ) {
return;
}
if ( wp_is_post_revision( $post_id ) ) {
return;
}
if(isset($_POST['post_order'])) {
update_post_meta($post_id, 'post_order', $_POST['post_order']);
}
}
上面的代码将自定义字段值保存在数据库中,并将显示在该输入数字字段中。
自定义字段中保存的值
按自定义字段更改 WordPress 文章的顺序
现在,我们将使用我们自己的顺序值更改 WordPress 文章的默认顺序。在显示结果之前,我们将运行pre_get_posts
动作钩子来修改现有的WP_Query文章。
pre_get_posts
给我们一些解决方案来修改wp_query
无需编写自定义WP_Query。
function pre_custom_post_order_sort( $query ){
if ( is_home() && $query->is_main_query() ){
$query->set( 'orderby', 'meta_value' );
$query->set( 'meta_key', 'post_order' );
$query->set( 'order' , 'ASC' );
}
}
add_action( 'pre_get_posts' , 'pre_custom_post_order_sort' );
上面的代码示例将更改博客页面或主页上的 WordPress 文章顺序。
我们在这篇文章中检查了一个主要查询和主页,然后使用meta_key元值设置查询顺序。它将检查文章是否具有自定义字段值,并根据字段值将它们置于顶部。
在模板文件中按自定义字段排序 WordPress 文章
您还可以创建自己的自定义WP_Query以按顺序显示文章。
您必须创建一个WordPress 自定义模板页面,然后您可以在该模板中编写自己的查询。
在此处查看有关如何在 WordPress 中创建自定义页面模板的分步指南。
好的。您现在有一个自定义模板文件。因此,在该模板中编写以下代码。
$args = array(
'post_type' => 'post',
'meta_key' => 'post_order',
'orderby' => 'meta_value',
'order' => 'ASC'
);
$query = new WP_query ( $args );
if ( $query->have_posts() ) {
while ($query->have_posts() ) {
$query->the_post();
if ( !empty(get_post_meta( $post->ID, 'post_order', true )) ) {
the_title();
}
wp_reset_postdata();
}
上面的代码将按自定义字段值显示文章标题顺序,并根据自定义字段值将文章置于顶部。
您还可以在functions.php 文件中创建上述代码的简码,并在小工具、页面或您想要显示文章的任何地方使用该简码。
就是这样。您已完成按自定义字段值显示 WordPress 文章顺序。
好了至此关于通过自定义字段重新排序 WordPress 文章方法就结束了,更多关于WordPress技巧请查看下面的相关文章
来源:https://www.wpdaxue.com/how-to-reorder-wordpress-posts-by-custom-field.html


猜你喜欢
- 本文实例讲述了Python使用pickle模块报错EOFError Ran out of input的解决方法。分享给大家供大家参考,具体如
- 在之前的一篇文章我们已经介绍过替换python字典中的key值方法 ,本篇文章将作为那篇文章的补充。使用 dict.update() 方法替
- 本文实例为大家分享了Django实现文件上传下载的具体代码,供大家参考,具体内容如下一、django实现文件下载(1)、后台接口如果从服务器
- 如下所示:#-*- coding: utf-8 -*-#code:myhaspl@qq.com#12-1.pyimport sysreloa
- 1.下载pyinstaller并解压(可以去官网下载最新版):https://github.com/pyinstaller/pyinstal
- “博客就像一本书”这话其实几个月前深圳FB时就有扯到,这也不是什么新概念,也许本身就应该是这样。打个比方,当你拿到一本未看过的书时,理论上你
- 本文实例讲述了Python实现的视频播放器功能。分享给大家供大家参考,具体如下:# -*- coding:utf-8 -*-#! pytho
- Python 网页解析HTMLParse的实例详解使用python将网页抓取下来之后,下一步我们就应该解析网页,提取我们所需要的内容了,在p
- 楔子当有多个 IO 密集型的任务要被处理时,我们自然而然会想到多线程。但如果任务非常多,我们不可能每一个任务都启动一个线程去处理,这个时候最
- 本文实例为大家分享了javascript canvas实现雨滴效果的具体代码,供大家参考,具体内容如下先看效果看起来很炫酷,其实就是实现了雨
- 函数的增益值torch.nn.init.calculate_gain(nonlinearity, param=None)提供了对非线性函数增
- Mac版Python3安装/升级Mac系统自带Python,但都是2.X版本,非常老的版本了。如果我们需要安装Python3版本,怎么能快速
- 1、Mycat 应用场景Mycat 发展到现在,适用的场景已经很丰富,而且不断有新用户给出新的创新性的方案,以下是几个典型的应用场景:1.
- 前言Python 读取数据自动写入 MySQL 数据库,这个需求在工作中是非常普遍的,主要涉及到 python 操作数据库,读写更新等,数据
- 这篇文章主要介绍了Python测试线程应用程序过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋
- *和&的区别 :& 是取地址符号 , 即取得某个变量的地址 , 如 ; &a*是指针运算符 , 可以表示一个变量是指
- tkinter 下拉日历控件网上找的不完善的Tk日历进行修改的,可以快捷的找到并返回日期。效果如下图,上面的是控件,下面的是调用demo窗口
- 前言大家好,今天给大家带来绘制“手绘风格”可视化作品的小技巧,主要涉及Python编码绘制。主要内容
- vue安装less依赖一、安装less依赖npm install less less-loader --save二、修改webpack.ba
- 本文介绍了三种跨域访问的方法,php,asp及jsp种访问远程文件的方法。这几天脑细胞剩下的不多了,不过问题都一个个解决了。我希望搜索引擎能