WordPress 文章按照自定义字段排序
像素鱼丸
11-18
171
0

在 WordPress 中,如果你想通过代码在文章编辑页添加一个自定义字段 list_order,并在使用 WP_Query 调用文章列表时根据这个字段的值进行排序,可以按照以下步骤操作:


✅ 步骤一:在文章编辑页添加自定义字段(list_order)

你可以使用 add_meta_box() 函数在文章编辑页面中添加一个自定义字段。


// 在 functions.php 或自定义插件中添加
function add_list_order_meta_box() {
    add_meta_box(
        'list_order_meta_box', // ID
        'List Order',          // 标题
        'render_list_order_field', // 回调函数
        'post',                // 后端类型('post', 'page' 等)
        'normal',              // 位置
        'default'              // 优先级
    );
}
add_action('add_meta_boxes', 'add_list_order_meta_box');
function render_list_order_field($post) {
    $value = get_post_meta($post->ID, 'list_order', true);
    wp_nonce_field('list_order_nonce', 'list_order_nonce');
    echo '<label for="list_order">Order:</label>';
    echo '<input type="number" id="list_order" name="list_order" value="' . esc_attr($value) . '" />';
}
function save_list_order_field($post_id) {
    if (!isset($_POST['list_order_nonce']) || !wp_verify_nonce($_POST['list_order_nonce'], 'list_order_nonce')) {
        return;
    }
    if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE) {
        return;
    }
    if (!current_user_can('edit_post', $post_id)) {
        return;
    }
    if (isset($_POST['list_order'])) {
        update_post_meta($post_id, 'list_order', sanitize_text_field($_POST['list_order']));
    }
}
add_action('save_post', 'save_list_order_field');

✅ 步骤二:使用 WP_Query 按 list_order 排序

在查询文章时,使用 meta_keyorderby 参数来按自定义字段排序。


$args = array(
    'post_type' => 'post', // 可以是 post、page 或其他自定义文章类型
    'posts_per_page' => -1,
    'orderby' => 'meta_value_num', // 使用数字排序
    'meta_key' => 'list_order',
    'order' => 'ASC', // 或 'DESC'
);
$query = new WP_Query($args);
if ($query->have_posts()) {
    while ($query->have_posts()) {
        $query->the_post();
        the_title('<h2>', '</h2>');
        echo '<p>List Order: ' . get_post_meta(get_the_ID(), 'list_order', true) . '</p>';
    }
} else {
    echo 'No posts found.';
}
wp_reset_postdata();

? 注意事项

  • meta_value_num 用于对数值型字段排序(如 list_order)。
  • 如果字段是字符串,使用 meta_value
  • 确保字段已保存,否则可能为空或不参与排序。
  • 如果你使用的是自定义文章类型,请将 'post_type' => 'post' 改为对应的文章类型名称。

✅ 示例:按 list_order 升序排列所有文章


$args = array(
    'post_type' => 'post',
    'posts_per_page' => -1,
    'orderby' => 'meta_value_num',
    'meta_key' => 'list_order',
    'order' => 'ASC'
);
$query = new WP_Query($args);
if ($query->have_posts()) {
    while ($query->have_posts()) {
        $query->the_post();
        echo '<div>' . get_the_title() . ' | Order: ' . get_post_meta(get_the_ID(), 'list_order', true) . '</div>';
    }
}
wp_reset_postdata();

如果你有更多需求,比如支持多个自定义字段排序、分页、筛选等,也可以继续扩展这个逻辑。需要的话我可以帮你进一步实现。

收藏
打赏
WordPress 中 Site Editor(站点编辑器) 和 Customizer(自定义器)的区别
上一篇
HTML元素中 title和alt 属性的区别
下一篇

发表评论

注册不是必须的

像素鱼丸
152 文章
0 评论
4 喜欢
最新文章

网站的 Cookie 弹窗

在当前的法规环境下(截至2026年4月),一个合规的Cookie弹窗设计必须遵循“透明、公平、明确”的原则,核心是确保用户拥有真正的选择权。 以下是现阶段设计合规Cookie弹窗的关键要点: 现阶段合规设计要点 禁止默认同意 弹窗出现时,所有非必要Cookie的选项都不能被预先勾选。用户必须通过一个明确的、主动的动作(如点击按钮或勾选方框)来表示同意。 提供平等的选择权 “拒绝”按钮必须在视觉上和 […]

网页设计中 banner、jumbotron、hero 都有什么区别

在网页设计和开发中,banner、jumbotron、hero 这些词通常指代页面顶部最引人注目的区域,但它们在具体含义和使用场景上有所区别。 🎯 核心概念辨析 Banner (横幅/条幅广告) 这是一个非常广泛的术语,通常指网页上任何矩形的广告或信息区域,可以出现在页面的顶部、侧边或底部。它更偏向于广告或信息展示的功能。 Jumbotron (巨幕) 这个词源于 Bootstrap 等前端框架, […]

宝塔 Nginx 拦截了 WordPress 返回 404 的状态

REST api 接口中,有段代码返回404,但是没有正常返回错误json: $wp_response = new \WP_REST_Response(array('error'=>'没有找到数据')); $wp_response->set_status(404); return $wp_response; 返回内容是: <html> <head><tit […]

Mirage 主题 v2.93.0 发布

更新内容: refactor 移除图片高宽比开关 refactor 移除全局的TOC生成开关 refactor 优化 header.php 中的seo模块和样式覆盖 feat 主题启用的时候,移除非当前主题注册的小工具 fix 修复分类小工具的bug feat 管理员打开后台,检查最当前设置首页布局的模块,如果缺少最新模块,就添加到隐藏模块列表中 fix 优化链接卡片样式 fix 优化热门文章样式 […]
生成中...
扫描二维码
扫描二维码
用户登录