找回密码
 立即注册
查看: 2330|回复: 3

如何快速在wordpress后台中增加一个发布全站公告的功能?

[复制链接]

338

主题

520

回帖

3458

积分

管理员

积分
3458
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:
' D) i# J7 e/ @7 [, Z& ^8 t$ C' G
/ V, I3 U4 U, a8 b/ l1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。
5 }/ S' c% G( |# |, l$ _( \8 P6 |1 q1 W- u7 E& ?6 B+ @
2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。
+ o' m# l' w$ J8 B; @' h
, q' w) q6 ~5 K8 n1 r3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。
2 j0 r0 X1 |, k. O
# ]8 i  _( e/ h4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。
; T$ G4 N9 I9 [" L- i
, |0 U; L) c) w& U) b注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

338

主题

520

回帖

3458

积分

管理员

积分
3458
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?0 A; c% I( V* L! h
/ ^  ]+ b( T4 ]6 b2 ^1 e' p
如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
/ Z* l+ w7 k, [& P) R5 v) ?! i/ k2 h4 `' ]1 h& Z& R. U( \( M/ n; v! F
1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:3 J+ _  |3 C" A5 u2 V' B8 T
& D' `* w$ E& Y: v/ n2 c
   ```$ ]9 M$ g3 T5 R. E: c8 J* ~2 o
   add_menu_page(
9 J& f& A( s! ]2 j& o       '全站公告',
* L  `* B8 H+ K2 `$ [. i( Y# [5 U       '全站公告',+ b) Z) y5 S+ L+ ^! k) D7 z
       'manage_options', //需要的用户权限
% q0 @8 u- I& G: U7 Q' P* {2 k- }       'site-wide-notice', //后台页面的 slug# o5 R% |3 F# z. x9 H- G
       'render_site_wide_notice_page', //用于渲染后台页面内容的函数$ G3 V, y& [* O2 c
       'dashicons-megaphone', //用于显示在菜单中的图标' H5 r8 Q' g& ^2 `" C, z5 s$ N, Z
       30 //菜单项的位置, Z* u- `# N/ f3 T: Q& o
   );
9 Q3 [/ T' J! [; T8 l7 ]   ```
( J5 i/ V' G3 }0 t3 C0 S' B4 Z0 Y: ^
   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。
/ T8 e( A( h5 {  v) H6 ]9 e
0 q: e' U, T2 H2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:# _* _* a8 p5 {5 e

: ^! f/ _7 h6 \: @! s* P   ```
8 \8 W$ v, o' _9 }   function render_site_wide_notice_page() {$ x1 O. T1 Z( Y  u# X. `; T
      // 渲染后台页面内容
% Q: `8 _% r# F" k; O9 k3 y      echo '<div class="wrap">
$ v, n6 e# e' v          <h2>全站公告</h2>
0 B1 V3 f0 s# G4 H# X( p          <form method="post" action="">/ f* B7 N2 g8 r# h5 y+ M
              <label for="title">公告标题:</label>
, y" r8 ^7 U7 @5 W              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>
6 B, ]2 u) A% X4 |) l              <label for="content">公告内容:</label>
* q( C- U- Z' j+ n( O              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>
% @% C* ?; A" F7 M9 H8 M2 M7 b              <input type="submit" name="submit" value="保存设置">( j9 ]$ G6 u" C2 _+ E' f
          </form>
7 v, d5 B) x6 R& y* @9 w+ k0 ^      </div>';. U/ {: [. ?2 z- ?( f
8 Y7 \7 f' {2 {& L1 s: C
      // 处理表单数据$ D5 n* K& K/ L& a
      if (isset($_POST['submit'])) {
+ b5 g3 m' l1 i! K$ p7 i          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));
9 p& ^  {" y7 h8 x0 D& g. R/ f          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));% U) n5 A# m- s) F% k. X- l9 E# x* m8 R
      }
/ D; ]$ j4 h6 x# i, B) l+ m' W  |. K   }( o! t8 x/ P3 I* i, K7 v7 W9 y
   ```
0 B; ~* S4 U. n  k5 u; f6 S
* V8 |9 m+ T3 `: h9 s3 g   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。8 u& o6 z7 D' x  {
4 r& Z# t1 ~: o# f* F  W
3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:! p& v9 j* @1 v0 G7 Y$ T8 u  f4 u
- d8 W: f% u3 e
   ```9 c/ n1 S! ^9 n5 k+ T
   <?php
- }  `4 G$ P7 j- {2 A# P7 ]   $site_wide_notice_title = get_option('site_wide_notice_title');
" t/ q: p8 l' G- ^   $site_wide_notice_content = get_option('site_wide_notice_content');# ^0 [/ J+ ]; b  l3 @, ], n* ]6 E' p- y
   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {
1 Y( N, Z& a. z) X" a: S2 i7 R       echo '<div class="site-wide-notice">';; K2 U8 @3 @- Z) h9 c
       if (!empty($site_wide_notice_title)) {
/ i% q( X2 Y1 A7 i2 O# n( }  S. U           echo '<h3>'.$site_wide_notice_title.'</h3>';7 _$ r. x) \, y9 ~8 U  S
       }
0 `6 q5 V* P- [5 G# R5 B1 ?2 U! d       if (!empty($site_wide_notice_content)) {  W7 [0 }1 s2 _+ \4 y# a$ p
           echo '<p>'.$site_wide_notice_content.'</p>';
+ I- U( D9 _- \+ y# m7 q1 q: U5 g: `       }  t5 n* e+ [& j! ]! R
       echo '</div>';
1 m# f: u' k( T) S; a* Z   }3 O5 `8 R' I3 m; e1 ]6 H/ q
   ?>
8 X, }+ T, Z, q* y   ```
6 r2 o, y0 z) I9 e# \# k5 s( f
! T: [& @$ y" j; d3 T; k9 \   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。1 N  h' X; }& U& r
0 a8 q$ b8 y0 ~& t, r. i
请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

338

主题

520

回帖

3458

积分

管理员

积分
3458
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?5 i+ Z( I! \+ n3 m  e
  Q8 P, d+ |3 s" W
您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:
7 l! n- {" b( Z# j1 }: \- o2 O
. k7 Q2 Z. D6 {3 s2 E( T1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:0 u# b+ H# F/ M: c% @1 \" }* X/ A

- u  q& ~2 M- W  n: B# _! {```8 K$ `/ a; A, A- y* Y2 @& V0 F3 L
function create_custom_post_type() {; G3 Z6 P; q# G* f+ ]
    $args = array(
- x1 G: d2 Y  ~4 t        'labels' => array(
. y. q% e7 j$ [9 O+ n            'name' => '公告',  o& j( P( x1 j; W
            'singular_name' => '公告', b1 K6 F9 J+ n# ], y
        ),
) A0 e8 X4 V' I0 V& A3 V        'public' => true,
: B: `; s9 W2 p0 s        'has_archive' => true,
  d: G  x* m( W: P        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),6 B" I8 ~# _& l; y* S' ^
        'taxonomies' => array('category', 'post_tag'),. R9 r! Z5 l. i# S* P9 c: G
        'menu_icon' => 'dashicons-megaphone',
2 Y0 y+ ]: R( h9 c  {- u) H+ y) A        'menu_position' => 5,
# T$ _& ]: @% m9 v/ m        'rewrite' => array('slug' => 'site-wide-notices')
2 Q6 P9 O" t& g9 f1 d    );
& A. m/ o, n; I- Z7 d    register_post_type('site-wide-notices', $args);
# H" V# e- m8 Z; |}
/ {1 Y1 v2 a. f6 hadd_action('init', 'create_custom_post_type');' R" p& q1 ~- I5 o- C3 {! ]
```5 s# d0 d/ |1 ]3 W: \  M
9 L  m3 z' L3 d$ Z& S. [) Z8 J
在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。- _; A8 j# v/ Y5 W1 F! `; r
+ @7 o  j: C6 `' P# L  M& ~( p: g& M& d
2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。
) {2 C3 K9 G2 {! r6 M7 F6 C0 k4 M
3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:
: K% I" t: ~+ K
! O3 H8 C7 B5 N```
  @" q2 p" D2 t2 |( \7 W  W' }$args = array(2 x7 n" o0 b; z4 c( |
    'posts_per_page' => 3, // 显示的公告数量3 s8 X4 q% [. u% A2 a
    'post_type' => 'site-wide-notices', // 公告文章类型, v3 h. U+ v# v* ~0 M
    'post_status' => 'publish', // 公告状态
* v) O& h4 t# L    'order' => 'DESC' // 排序方式: n9 n1 \- w5 x' X; q
);
; V: C- k9 a: ~6 p! R2 [. W$ W3 V+ H1 Y
$notices = new WP_Query($args);2 Z+ v+ E4 }" K' b& M/ L
if ($notices->have_posts()) :
8 b  A( j( l2 J: \0 |    while ($notices->have_posts()) : $notices->the_post(); ?>
# H( p6 q4 N$ _4 \        <div class="notice">
1 V7 v, B! H( G6 W5 ~            <h3><?php the_title(); ?></h3>0 C3 h! S2 M1 p' q1 [! `7 ^! c
            <div class="notice-content"><?php the_content(); ?></div>
# T3 y2 Z, I2 C! l2 k# q        </div>" N3 M6 M6 l0 O
    <?php endwhile;
+ d+ ^9 I5 z! m# m' f: w, I$ c1 H& C1 Selse :# ]. q8 O1 O, W. o
    echo "暂无公告";
3 o5 ~! c; Y( v2 a! gendif;
4 n  B* z; B: o5 [+ _wp_reset_query();
; h0 M8 K0 S; S4 T```' ]  `; a, Y: c, K$ G) g  N! R

0 X. s" E) D# Q8 `这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。0 d6 L2 X6 R5 U5 a) n: b

4 t! J( u' ~( a7 v5 X: O4 e' s" J以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

338

主题

520

回帖

3458

积分

管理员

积分
3458
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?5 @  @: o. n( F+ t7 U
( U& Z4 L3 O8 _: V
如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。, [0 T, _1 C! B) K( G% n' m7 Q  x0 x

% e/ ~% ^6 F( k/ h9 G- B; g/ K以下是创建自定义插件的步骤:+ o0 b9 _. c- h- n5 ~

9 [7 p  k; p  c3 d1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:( `# _& ?3 v% u% y. W; D/ U
. b! B8 _" W0 {' {
   ```/ @$ J* F6 W% W5 \
   <?php
6 |8 X: L8 [6 R; ~7 {8 a) D) ]   /*% T3 O4 T0 l( m$ P6 `& K/ q, Y
   Plugin Name: Site Wide Notices Plugin* f( v- U7 y' }2 \. r' I
   Description: Adds a new custom post type for site-wide notices.8 ^& F1 O9 D7 g6 w) G, a, R
   Version: 1.0
  f: k9 ?4 q5 S9 A! n, W   Author: Your Name! r7 w" S% q9 q5 N& Y
   Author URI: http://example.com. d+ ]3 v: w, }& r5 F" |8 H
   */
2 ]% M2 Y) _+ d( J/ r1 h* @8 U
: Q1 H. h1 A! ?" D+ }/ K4 F3 k   // Add plugin code here...
; M+ Q+ @) \# `# C. ]3 r   ```3 ?( i% y$ b5 b  z$ H

0 W  k4 O% M/ Q; J$ o   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。
, L+ {  `& }) @$ [, i( V2 K3 R' ~9 l# p* s
2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:  E3 d0 l$ v& B+ ~6 h$ {$ W

; \$ x+ d& Q0 L/ Z: m( `   ```; h8 i+ _" J2 U& Y  e, Z0 `
   add_action('init', 'create_custom_post_type');; i& z. D2 G: h& x
   function create_custom_post_type() {
+ ?3 u2 W5 w; X+ ^/ ?( \3 a      $labels = array(
! N6 B0 W; U; ]+ i; s          'name' => 'Site Wide Notices',! y: y  Q. T7 T; h4 U0 P
          'singular_name' => 'Site Wide Notice',: _2 y# H# Q" L2 j" }+ \7 L3 H
          'add_new' => 'Add New',
' B  i7 u! O& l5 i7 h" ^: M' U          'add_new_item' => 'Add New Site Wide Notice',
8 m4 W+ `2 F+ z2 z* B          'edit_item' => 'Edit Site Wide Notice',
, M+ B% b+ ]" p; ?; N9 Q/ f2 `          'new_item' => 'New Site Wide Notice',2 \) v- z# d" P# d5 O/ v$ h
          'view_item' => 'View Site Wide Notice',# a4 ]  o, H$ E" k$ n
          'search_items' => 'Search Site Wide Notices',$ o+ L" I, S9 s% g# X+ x" g
          'not_found' => 'No site-wide notices found',% a& k* x- G6 M
          'not_found_in_trash' => 'No site-wide notices found in trash'
& Y  f1 `9 P4 ~( w      );
& I1 ^3 _, H& T4 K! k: a- i: L; x9 P2 e; k/ v6 D9 J) z/ Y8 h
      $args = array(
, F! o) F1 Y' `1 \          'labels' => $labels,# x+ M' ]6 o# F7 N# Z$ L
          'public' => true,
* i. ?7 j( y2 V' u          'has_archive' => true,
4 G& ^6 k7 Q1 G' J1 y# E4 I          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),+ V& L; j, }# [% B5 P2 y
          'taxonomies' => array('category', 'post_tag'),
# j: H+ C' h* y% D* L4 Z          'menu_icon' => 'dashicons-megaphone',
# `  m, `' }! P8 E0 k          'menu_position' => 5,% N2 n5 B6 m1 m' n8 J: \, k% t; ^
          'rewrite' => array('slug' => 'site-wide-notices')
2 k' d& X+ [( p* X+ [2 [      );
0 ?4 N1 n/ w, N1 g) }( ~+ K; C* t5 d5 y  x, A6 n8 o3 B
      register_post_type('site-wide-notices', $args);0 ~2 }# v' ?0 \. I8 x6 X9 z/ j
   }
* K" M6 J  f# K5 U" K5 G' o   ```
0 R! m+ i! H, ]4 m  Q7 d; g) C& o( H3 C. n, U/ x; r" T4 l* g' U
   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。2 i5 L$ S2 v+ l5 n4 z: u

2 d  T) f6 d8 p, d4 d3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:
9 n- x1 \6 F1 a' M- G( u. r/ a
9 Y0 M9 n/ `7 y' p. E   ```1 R/ n* B6 H" j2 d/ |
   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');  o) \4 A9 e3 S# C
   function add_site_wide_notices_boxes() {/ w1 {9 D8 e4 z4 g  a  r
      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');
3 p; Z6 ^, @# ^+ e; f3 g6 m   }+ E( b9 P: f  m9 y- u

) D+ w! E6 n% v* C# O4 C   function notice_details_meta_box($post) {
/ e( \3 m5 I' L+ _" ~      wp_nonce_field(basename(__FILE__), 'notices_nonce');4 y4 _7 H* T) k" _# B) c
      $notice_title = get_post_meta($post->ID, 'notice_title', true);
! f2 j- `. b5 F) `& `+ _      $notice_content = get_post_meta($post->ID, 'notice_content', true);5 m& ?5 [" S* V( U- @# i+ M
      ?>/ z+ p; x, i7 r; j3 f
      <p>/ {6 q& l0 ^, s8 N+ |0 v( P
          <label for="notice-title">Notice Title</label><br>% D! v; t- @  F/ c  z# I1 @5 B
          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">/ D1 P. P0 j8 t8 A, Y% T
      </p>. F( J' }: z9 e
      <p>, `9 K6 R9 D' ^
          <label for="notice-content">Notice Content</label><br>
/ K+ ^- D3 a! q4 T" T; u1 x          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>4 L0 Q: u: ?9 z, |
      </p>0 M+ Z, N$ S3 l7 B& V! I, M, j/ i
      <?php, P6 F6 Q, _4 z7 ]5 v; Z4 @* H+ h
   }
2 t9 X1 c: x" |4 C, ~+ E/ H
7 {: }4 E* h" |/ c( e   add_action('save_post', 'save_site_wide_notice_meta_box');
& l$ X3 H4 d) Y) O4 z! t0 Z   function save_site_wide_notice_meta_box($post_id) {" G8 r3 ?3 U3 h
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))) w- D# ?( s* |* E* x) z4 U
         return;/ m& n% l8 d" ~' P5 `( i
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)
. i6 u2 O7 m0 `/ }% L1 ]         return;
9 _6 x! |' T& ]& J8 z. }7 q1 N6 \+ {6 {- }/ q" m
      if (isset($_POST['notice_title'])) {
$ L5 G+ V) h. ]$ O5 {$ n* o2 r/ o3 H          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));
4 ]7 [$ D, J: x0 W. w9 J+ y      }: ?* x- \% x, a( m# \/ z
      if (isset($_POST['notice_content'])) {; a$ v/ K: v% x6 {* `+ w1 s
          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));
8 {. e$ Q$ F- q9 Y7 B      }$ q& X% A) r. e
   }7 ^6 k, x- y2 E& z# G9 z' ?' o8 x
   ```7 h: f& O: e( [2 X: b% k) h! B# A

& |* }7 v# H9 K' {1 q" z4 s* X7 A2 Q: H   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。0 x  u* n' ]0 v' K

4 Q6 P" w0 {! D" o* @# P4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:2 m: D4 \4 l, }8 J( J4 e# j
4 X2 L; R* S( I# C  K3 G& }
   ```
( M) h8 @% A' t" O, z( O- ~   $args = array(5 _2 [! F( |+ O- U) G2 [
      'post_type' => 'site-wide-notices',
# h! d* V# T5 q. ?      'posts_per_page' => 3,8 m8 y. z7 T# J2 g/ F9 [
      'order' => 'DESC',3 h- g1 ?+ _" G
      'orderby' => 'date'
5 d+ ~$ K" X0 @   );( R  B! H( z7 X
   $query = new WP_Query($args);& r, ?  G+ p! A- B1 V
   if ($query->have_posts()) :& E9 ^9 ^% V* B5 Z
      while ($query->have_posts()) : $query->the_post(); ?>( E  R- |% H- I8 N+ F+ C
          <div class="notice">
! W5 K5 X: F; b& J5 r              <h3><?php the_title(); ?></h3>" b% e. F% b# \: A1 ]
              <div class="notice-content"><?php the_content(); ?></div>9 h9 d- G. l! U$ J5 Q1 m& W
          </div># c" [% g. R+ Q8 y7 Y: }) R
      <?php endwhile;
* ^6 ~& i7 f) m; A  Y9 b/ r+ J      wp_reset_postdata();6 `* W3 j$ n* s! z
   endif;
3 w4 w5 h" Y9 v   ```
/ t( u2 O7 i: l1 }! P  T9 G2 H$ I( m3 k+ \' J
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|通达创业无忧 ( 粤ICP备2023021749号|粤公网安备 44030402006137号 )

GMT+8, 2025-12-31 09:50 , Processed in 0.015692 second(s), 3 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表