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

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

[复制链接]

340

主题

529

回帖

3528

积分

管理员

积分
3528
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:
6 w# n( W  d- x5 j# r
/ W; w/ `+ O  t& L( z2 t1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。
5 P; C; n; X( L4 @6 [* U5 o6 c$ H$ z
2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。
9 ^! z" a! o( V4 w5 q1 h
, ?) {1 s7 g# H- w9 R; F8 A6 U3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。
2 y+ m, K3 B! Q; L3 f' l0 b( S6 J
4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。
7 T9 a0 q; _7 y& }9 ^8 f5 z& H8 k  k4 G! I! x5 u
注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

340

主题

529

回帖

3528

积分

管理员

积分
3528
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?
" a) m/ n+ U! A5 G2 b" F# r0 e3 |5 p" b; D% B  r% s( d5 i
如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:& _1 S8 @: p* x8 f3 I

: u+ G2 }% `8 G9 w1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:. z, }! U5 }) i* p! L; P
& @) q' x. X9 g
   ```
' B& t- l/ Z( Y+ H3 P   add_menu_page(( @# h  V9 @. Y% [) _
       '全站公告',2 i, o& ?& d4 l
       '全站公告',
+ B: c) }/ g+ a. }       'manage_options', //需要的用户权限
/ \' |! I- _4 C, y" `       'site-wide-notice', //后台页面的 slug
) O% q6 w7 \/ W" C" d       'render_site_wide_notice_page', //用于渲染后台页面内容的函数' K% _. z1 s) E6 f  Y; T. J
       'dashicons-megaphone', //用于显示在菜单中的图标3 Z) j3 M; {0 z! }" y
       30 //菜单项的位置" _  p- Z+ j# T2 Y6 {+ B/ q
   );
1 _* r% G; O/ a* \0 d   ```, L. ^4 O+ Y1 \8 _' X3 Z$ Z

3 K1 j! E, D. i5 T* M) L6 H   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。: @, s8 e" A7 s7 n" @* [2 _
8 Y  x; m( h+ {. R& Y6 A4 e
2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:4 x" o9 W1 W8 S0 q. I

: N# l7 v+ n, u# V   ```
( l9 h) w9 l6 o3 X8 `' D" v- m   function render_site_wide_notice_page() {
4 y9 W& }4 p0 y, q9 K      // 渲染后台页面内容
$ j' }6 T' R' T& e& X      echo '<div class="wrap">
$ g' Y5 R) F- X8 u$ q: E          <h2>全站公告</h2>& O- k% X, w2 U; F  z
          <form method="post" action="">
& b! f2 m4 l& b' R7 b: A              <label for="title">公告标题:</label>
! y( O% a) n7 l& t              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>+ [0 d1 \: H8 B3 i
              <label for="content">公告内容:</label>
7 n' [/ l0 n, P( c+ n) w6 a; G              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>
* m/ H. T- }: J0 o: d              <input type="submit" name="submit" value="保存设置">
0 ]5 w2 {; r! M$ \$ C$ V2 X          </form>/ O, L( t& O# V" Z- r2 N
      </div>';) Y9 E4 }: x: O- _- H8 Z! c, y$ W

1 O, N/ e6 C6 y1 M: }      // 处理表单数据
2 [, J  }" K0 k9 O      if (isset($_POST['submit'])) {5 w) [. D. X  [* u; k, K
          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));6 H; T" r$ d+ i) j) i
          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));
& ]6 P6 O4 S; h6 {+ M* B      }, s/ ~1 s" q  f' l1 ~
   }
8 i! J) _: [- X6 U6 O1 |2 P   ```
3 N0 U+ Y. [  z  B& L# t" S
6 X$ r* T7 @- l5 W  i/ s) S5 p   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。$ k& P* k9 G5 z2 N! P/ K8 H
4 a1 w, g9 w: \
3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:( G: O$ L) P/ j. V. `, G) ?& r1 V' U
$ j7 b# x* V8 `" S
   ```9 u; m# [+ `. t. \  W
   <?php
+ P0 k- s# c4 d8 k9 T" r4 B   $site_wide_notice_title = get_option('site_wide_notice_title');. h( Z* F* c7 \9 ]
   $site_wide_notice_content = get_option('site_wide_notice_content');
7 P% ~$ j4 G( f6 t   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {
. O+ `2 T- ]" m4 d0 n       echo '<div class="site-wide-notice">';: Y9 O* G) r. c) A/ ^1 W
       if (!empty($site_wide_notice_title)) {$ h% `  C) f3 O3 d1 t' O! L4 g
           echo '<h3>'.$site_wide_notice_title.'</h3>';4 \. Y2 |! O. u6 M5 Z, T
       }
6 ?# M% o! T9 @  k' Q, m       if (!empty($site_wide_notice_content)) {7 n9 ]7 D! F3 q* ]  v
           echo '<p>'.$site_wide_notice_content.'</p>';5 J* Q* |) k2 j9 O7 j) O
       }
3 P4 r) u0 u. ], l+ k! \       echo '</div>';
& L4 z* y+ W/ p9 m+ L   }
9 E$ q0 }* L/ P9 q7 F2 ^   ?>
- Q4 ^" ]6 _9 c& l# P   ```
1 l5 y! U3 t  c9 B
7 P. y" ^2 V; m6 U  M( \* E   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。
, K3 O' l- ]; [% m
3 c1 \6 z& Y/ c8 i. z2 k* x) i) _3 L请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

340

主题

529

回帖

3528

积分

管理员

积分
3528
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?
; ?9 n# J$ ^, B, R' s" t4 E( Q  x. S( \7 M
您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:
: d( J) |) E) K* t. I# |
$ x  T2 O; k, d! R1 a: {1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:( b0 ]0 S- M1 i1 j" G2 e

6 L4 ]9 r( h! x$ p: v; l6 l```: U( d6 B( l" |% ?
function create_custom_post_type() {
' ~7 ]5 @" K5 z1 D/ b  s    $args = array(
! t5 p% j; e5 c: V+ w1 Y+ {6 Y        'labels' => array(
( Y1 B8 t2 e4 D9 w. y            'name' => '公告',( c5 N/ S, G# k6 E
            'singular_name' => '公告'
* x1 ~0 x% D" Z& b/ e* \5 u3 l* y% l        ),
; I' N: {2 L2 J! N- l        'public' => true,& y5 R1 T) @9 Q. k0 T. p" O  [7 ^
        'has_archive' => true,- ?" H1 O5 z: R. A9 ?
        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),: T! K6 b8 u6 M5 ~. _- _, U& ~
        'taxonomies' => array('category', 'post_tag'),3 a0 R5 n7 e3 L  W! q+ |6 m% K
        'menu_icon' => 'dashicons-megaphone',# X0 {  B- N* f! }. s1 w
        'menu_position' => 5,) {* V8 P0 e& |2 n' l0 N
        'rewrite' => array('slug' => 'site-wide-notices'): b: m5 f7 D0 E% t  l
    );- j: w2 @4 {1 Z5 U! v  t  g
    register_post_type('site-wide-notices', $args);
* i6 Z* }) T: o& b7 i0 }7 J7 I6 b}: A% ]3 j9 x! T' H# A9 S1 N/ ^# P' g
add_action('init', 'create_custom_post_type');% T( h1 `- T+ l/ M5 Q) t' Q, }
```) W! e: n+ ^  m% H/ c, u

& m, Y* e+ q- f" G) V4 d# ?在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。5 V3 @* D# `$ F- C2 w

% R) V% d: ?3 W1 H2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。
7 r: C* s; v  h
3 }( n" \# ~% v( L0 Y3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:
, I7 P" \- K% h0 L: Z1 T3 O6 B% \1 N( u8 E, |
```
5 |  S7 h- v7 p$ C! k$args = array(
' F. `7 u7 Y& d5 k0 R  p    'posts_per_page' => 3, // 显示的公告数量1 n' u1 D$ j: o  `6 e4 G
    'post_type' => 'site-wide-notices', // 公告文章类型+ ~6 s; C# K- c, r# ?5 j/ G5 x
    'post_status' => 'publish', // 公告状态
9 U/ }7 m" s8 o; t- s    'order' => 'DESC' // 排序方式, J: L, p: @. g8 _1 n$ E+ D6 v
);
3 j+ F2 [9 e8 c  h, Y9 c4 A
* `. f- W$ o( i" d0 V& [$notices = new WP_Query($args);
6 i# Z6 Q6 N  A& @# u  ]7 cif ($notices->have_posts()) :
  `1 S0 a) |( P3 s! _& {$ M4 D$ B    while ($notices->have_posts()) : $notices->the_post(); ?>2 x- c% \9 [; g. s% n" Y
        <div class="notice">
% l# ^8 A# \  w: e1 s            <h3><?php the_title(); ?></h3>
* L- v3 s, h  C1 I            <div class="notice-content"><?php the_content(); ?></div>$ A; D, V4 F2 W; A" f
        </div>
( l% _( ~. `" V4 L1 f- s/ D    <?php endwhile;
) z$ G. O" X3 B( Yelse :; f( s9 U4 }8 n, n
    echo "暂无公告";
' ]& y# S; C( v0 _endif;
/ `9 Z' d8 ^5 @' Uwp_reset_query();
! g/ k4 Z( Z. ^4 ?8 u% n$ h```
. t: C1 p5 }' y7 J3 l, S7 D# w) p9 B5 V
这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。
* R- P7 I6 M- R7 m6 D( D
8 F; ]! ]3 V9 n0 ~$ N4 X) V- t以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

340

主题

529

回帖

3528

积分

管理员

积分
3528
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?$ w2 f% I! |( X/ T
& j; i( _) v7 t0 L2 s* U# E
如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。
1 e+ U+ ~) X4 h& ?: `5 y' N  C. Y
以下是创建自定义插件的步骤:/ Q$ I  c/ G# |9 ~: ?$ p3 k

* \8 c' E+ Q$ H+ Z' K1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:  T" O' L  ~$ }; [

" W: K& ]9 ^1 G( {' N( L   ```
# K& N( F8 r9 u8 Z  c4 `; D   <?php, m- o) }4 [2 Q; w4 o- ]5 x
   /*  T0 w% ~/ f  b% N0 {  n* i0 [
   Plugin Name: Site Wide Notices Plugin! K4 \$ K6 v% g9 s8 }9 T$ w
   Description: Adds a new custom post type for site-wide notices.0 E& Q8 v& }  h
   Version: 1.0
' n8 ~6 d$ c' O   Author: Your Name7 j. O( w5 _2 B# \0 C4 Z
   Author URI: http://example.com% r! k  D6 N9 R2 N- T0 F( [* O1 E
   */$ o2 j! ~) t# x+ `4 V! a5 O
: X; N/ _, z  g1 A" [
   // Add plugin code here...
1 H8 R0 A5 z2 {: S0 T6 @7 v   ```9 M2 ?# e8 L$ n6 d# W. j
+ f# o& n, f5 C) I
   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。4 _% R. {9 @6 `6 l, P% T
" b2 o) ~: v: F4 f
2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:2 l3 t% \* i' }& s- t
% S2 {; l% X8 T8 [
   ```6 V; G7 m9 m4 @1 n
   add_action('init', 'create_custom_post_type');
& I' a+ z# }# Y. Z( x/ N( B) `   function create_custom_post_type() {
: p4 i; L% }) [% W      $labels = array(
( P3 ]- Z, w3 H* a0 q$ E3 l5 F          'name' => 'Site Wide Notices',8 Z! S3 G$ ^& c: [6 A
          'singular_name' => 'Site Wide Notice',
5 A0 X; ?: d+ {( S  A          'add_new' => 'Add New',
9 }2 E. T1 v2 }% k; W0 e" u          'add_new_item' => 'Add New Site Wide Notice',
$ O8 ]+ f0 }: G! h6 T) J1 c1 G- x) {          'edit_item' => 'Edit Site Wide Notice',
2 n; e* S7 b9 M3 I- A0 c, k" b          'new_item' => 'New Site Wide Notice',
8 o2 K2 p, x# m, [+ f4 K5 o          'view_item' => 'View Site Wide Notice'," Z  X" ~4 \& w* R4 Q  R0 Q) G
          'search_items' => 'Search Site Wide Notices',3 l* T- G$ E* f4 W
          'not_found' => 'No site-wide notices found',
$ Y5 a3 M9 c9 q# K          'not_found_in_trash' => 'No site-wide notices found in trash'# b, ?% D/ p% q+ N& b* z: d' b0 Z
      );
4 j3 Z* s" S7 [  j
2 K  @& z, D9 d( f% h- I      $args = array(; q4 j3 m  j& T9 X7 a8 ]! Y2 w$ N
          'labels' => $labels,9 |: i, g! w; l4 `4 H0 _# U4 m
          'public' => true,
6 ~! r0 V# Z+ D% \3 y; j          'has_archive' => true,
+ x, E. z7 O; }) c; B7 S2 O- {          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),+ s8 [7 T1 H8 X* I' l
          'taxonomies' => array('category', 'post_tag'),
) g; K' b1 g* A+ P7 x3 m          'menu_icon' => 'dashicons-megaphone',
" I# l$ h! t  V9 l8 v- }          'menu_position' => 5," h6 I% I% D+ C: `! M& s* f" V
          'rewrite' => array('slug' => 'site-wide-notices'); W' j( i1 m* P/ F  }* C7 c, v
      );
! X* ?( e# r  x, a% P
, c6 \* r3 G# K, ~! e+ y0 q5 Q! M      register_post_type('site-wide-notices', $args);
6 x0 J1 V0 V. K9 B. t% z" @   }8 n3 X7 B0 z4 v6 L7 z/ D# T
   ```, e8 x. i, h9 r. N2 H* P
7 d8 }6 n, F2 M/ g5 I+ y+ F; ]
   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。5 E) V. n' f4 Z6 g/ k
5 J! l! ]5 N$ \$ G( J) Y: w
3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:
+ g% X. X, R3 \7 P/ o1 L
) [7 j! q% X  V3 Q   ```& [1 ~' O: }0 s4 k& B3 n
   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');6 ^, Y9 u5 j2 M) z" Q6 p( c
   function add_site_wide_notices_boxes() {
$ c" C% W3 P* B* f  h      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');
9 Z5 ?  |$ O0 I# H2 M  @) E   }. K, _: J- W1 w( v
' }4 g. {& e  P$ ]5 [
   function notice_details_meta_box($post) {; `9 U+ z, w0 ]8 G6 L, ~
      wp_nonce_field(basename(__FILE__), 'notices_nonce');
4 n' D5 m6 P% i+ I1 `2 s      $notice_title = get_post_meta($post->ID, 'notice_title', true);
( c4 R$ N- r1 e2 Q      $notice_content = get_post_meta($post->ID, 'notice_content', true);
5 Z* X& [$ X" j6 A" z' u  F      ?>
# q1 A: q: k3 E+ E* p      <p>8 M7 J) t) w5 d
          <label for="notice-title">Notice Title</label><br>
3 Q4 N8 a4 h+ M& r0 W/ ?          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">3 Q$ |5 O1 w  y1 N  I: r. d+ q
      </p>5 D2 p: g0 L5 g1 Q  \
      <p>
0 _3 ~  e: r4 p! s' O          <label for="notice-content">Notice Content</label><br>
$ [% z; `+ b8 a* j) W* K& }4 i9 y' |          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>
! m! u: K- S7 O      </p>8 [' ~! X) ?6 V$ J, x
      <?php
' f% Q2 P* e1 e1 O1 a" {   }
  R/ @2 a1 K+ E- M
& Q% z. T: w3 y: l   add_action('save_post', 'save_site_wide_notice_meta_box');
! m! P  O$ J8 n; P0 ^% ?   function save_site_wide_notice_meta_box($post_id) {. i0 p' w+ x6 D! p$ v" ~
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))" @  [3 S# u+ n2 T7 H$ }6 q3 O7 M
         return;
0 S, `, c, d* e) w      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)0 `6 c# c) i& T7 x7 L
         return;5 y% Q5 x0 @$ a: {0 j; N' @) _

0 [( \; C0 p; n& R% A8 z$ [      if (isset($_POST['notice_title'])) {
& @0 P; B  ^. \, D: a          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));( h+ l+ X. P* h3 m9 k
      }
0 O) X5 H/ z& k0 P" i* {      if (isset($_POST['notice_content'])) {! Q( B# U" p' O8 L, F- |2 E4 p, {" _0 C; F
          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));$ v; u$ Z/ _3 {% B  g( ?# F
      }% a9 {% f  d1 r3 ^: ^$ a$ c$ k
   }
9 y- {  |) E8 {( K. S6 I   ```) V' R/ \; |0 X8 H1 @7 s+ O: e: Q
, ~: m  q$ a8 M3 k" i  d
   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。
- t8 V  o' \% v$ m3 o7 d# e% Z! g7 t# e+ u$ }& K
4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:% Q, A% F8 D4 }) g* i
) w5 N- k3 H; A' C$ k( z$ R7 j% z; }
   ```
; r  u. P. Z: w: S( X, X4 R/ s' l   $args = array(
# H# p) i, g0 N3 U/ A7 z      'post_type' => 'site-wide-notices',
5 H" |/ f% F* N; w# N      'posts_per_page' => 3,% K- J5 ^7 _% l( z
      'order' => 'DESC',& C9 R+ w* v" K8 ^" e9 r! i
      'orderby' => 'date'
) ~  P& v) P# t: r# @7 r7 m   );& L4 ?) U* `( \" c6 m4 Q: A; ?
   $query = new WP_Query($args);, E, O( h& g  @$ z# G3 r
   if ($query->have_posts()) :
9 i, N5 N8 X8 ~' b% o2 g      while ($query->have_posts()) : $query->the_post(); ?>
+ p2 {- ?! a$ Y          <div class="notice">; s8 L. G3 P0 \) c% m% i
              <h3><?php the_title(); ?></h3>
& @4 `$ m. _% p; e& D! U1 R              <div class="notice-content"><?php the_content(); ?></div>
6 l! r7 o. g/ R8 |' S6 Z          </div>; t9 ]+ G6 g  [) |) K( n
      <?php endwhile;
" T+ O8 _5 _% s      wp_reset_postdata();
1 T$ a  z! ~; [$ y6 ^' c, z   endif;) E0 @$ Y5 c2 v3 c/ O* l6 L
   ```# N  B+ O7 k. C% G- }% z

  D6 T+ Y* e! e+ l) i# ~   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-17 15:43 , Processed in 0.022104 second(s), 2 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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