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

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

[复制链接]

341

主题

541

回帖

3575

积分

管理员

积分
3575
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:( t/ j4 G5 j% Z- M  A8 R) s( f
1 m4 n; k  o' r2 w. V: |5 n% N3 R
1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。) z: }0 v( a; ^2 H* Y
! ]7 \5 |4 h5 c% D+ I, c% t$ F2 R
2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。" `) n7 o; c  T  K

& {! M3 T  i9 `# x3 U, T3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。( B) g" `8 \! I. b

4 I$ n# U0 I* K( s! V" \$ Y5 M4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。2 G# ?( l4 T" v

7 Q4 ?1 y% C8 n, F7 |注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

341

主题

541

回帖

3575

积分

管理员

积分
3575
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?
: Y; X) k4 ^7 n( f% L  J7 Z; }' m- i. }% A
如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
" R% l: d$ S0 V# F6 K2 |- _( f: [) Y) h1 h- Y, y. @
1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:/ [+ h% M) g, g" c1 P

) X3 x5 F, X6 a) i% T8 x6 m7 _   ```9 w2 e' K$ l' e
   add_menu_page(* g: b. |+ g6 E7 _5 `- Z0 p
       '全站公告',
0 r1 Q$ L6 U- q0 b# w6 f       '全站公告',( M1 P! P8 Y2 O* c5 {, [- I8 |) Z; \) f
       'manage_options', //需要的用户权限1 o% `) x9 K. B( b
       'site-wide-notice', //后台页面的 slug* m5 e/ Z6 H" j) A- _# c
       'render_site_wide_notice_page', //用于渲染后台页面内容的函数, f' u  y3 `8 @4 B0 j
       'dashicons-megaphone', //用于显示在菜单中的图标
( R" L, Q5 U# \; J& L( D  J' r: d' y       30 //菜单项的位置6 F- D+ ?6 C/ m, g2 ?5 P
   );
7 P5 d1 L; Q( }* }& e% h   ```& H$ m* l5 d, l( N2 g% `1 R
  V! z9 A6 F. b# \8 o
   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。
; f3 W1 I0 f, e* S0 I2 V
+ N/ J4 g6 q3 N1 ^, a9 ^& [2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:  T- L4 K  I( Q) l0 v. f8 M

3 v. [2 d3 ~- P" W: Q) S   ```8 h7 \, g1 ~2 p! ]) d  E" Z
   function render_site_wide_notice_page() {7 u  u. q4 N& k6 z& h
      // 渲染后台页面内容
8 |8 p7 q; k- k4 T* h" v6 Z      echo '<div class="wrap">
, ~  P" ]8 _. W& E) u9 q          <h2>全站公告</h2>
7 M7 M9 m. |) \5 M% p          <form method="post" action="">$ P2 u6 A$ H/ d  ~3 b
              <label for="title">公告标题:</label>+ k3 V/ E4 k# q  x9 N
              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>/ r1 U8 Q3 n2 a( K: C8 V& I6 t9 t
              <label for="content">公告内容:</label>
: W4 J, [$ X# J" f3 p0 {! T8 z              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>
; U, ]3 W7 P4 C* ]              <input type="submit" name="submit" value="保存设置">2 U0 A. J6 U5 D, [' r) d+ {0 r
          </form>
/ A# w+ Q9 v5 K; u) ^      </div>';
9 u  |5 `" \# Q- @: m* ]* v: O9 l
! |  R2 U! y' J2 `4 l6 g      // 处理表单数据
; i: R4 B( g0 H& ~- p( r; u1 U+ N      if (isset($_POST['submit'])) {
* a- r, k6 G/ P* B. `          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));, d! m3 P' s7 ^/ E& S
          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));
* i' P6 ^& w5 P& w/ X* @      }
3 j1 m2 M0 B$ f2 O7 `   }
/ z7 m6 K  k) D/ B  \# b9 b7 c3 b9 {   ```
7 d( _. f$ w2 e7 x$ H- t% h8 P0 {( r2 O# x  k1 E
   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。& w5 I/ W0 c2 \0 o/ U' v

2 c. F/ L; J& i( W! M% P) `3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:! k. Y9 ^0 g, h: h

8 ~( v- n6 c* ?! n3 @, V   ```
' x, E* C& j& O8 P+ f   <?php+ e) l& F! m/ c! J# z# L& {' n
   $site_wide_notice_title = get_option('site_wide_notice_title');
( ~4 [. [; D4 l" U2 r  N   $site_wide_notice_content = get_option('site_wide_notice_content');
, U1 w2 z! e$ n0 ~9 n: u9 ~. j. a   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {
4 ^6 s# k- Z( c- B7 ]- m  a       echo '<div class="site-wide-notice">';
  C1 Q2 `8 H: {/ t       if (!empty($site_wide_notice_title)) {8 r3 L9 S: S& u8 b
           echo '<h3>'.$site_wide_notice_title.'</h3>';$ {6 F2 W2 B. a: H
       }0 L. S( u" d7 W  u" T$ R
       if (!empty($site_wide_notice_content)) {  e' j. h( Q  Q
           echo '<p>'.$site_wide_notice_content.'</p>';. V; e- n4 j4 @( t- J- N; V' r0 U
       }( L5 W  g6 B, ], [" b) k" x( p9 J
       echo '</div>';
# C3 g, B9 Y8 ]7 c% T   }- x, l2 B- p. \2 S7 O
   ?>; v4 a& y- B* s7 ~. [/ j
   ```
' N3 j: V# r9 E' `+ c/ I$ q2 R( M7 S9 y9 d5 G; Y
   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。# o& b; r" X9 P3 g3 P' Z
8 d6 A9 h# k6 b0 L9 u- p/ U8 N
请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

341

主题

541

回帖

3575

积分

管理员

积分
3575
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?$ F; P2 B/ ^: i7 n' q+ Q& W8 `

" j% |5 A8 E8 W* J# }9 j3 A您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:
$ `: S# g- V. V0 Q2 w/ _: ~/ \0 _  {+ o2 u. k
1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:4 W; @8 b& \( p
. a: n$ g- W' h; P$ v& I+ X6 ^
```
9 V1 }( ~, I0 T, H4 Efunction create_custom_post_type() {
5 |! u1 Y! y2 r7 O6 e+ a    $args = array(
4 l% a- q6 W- v1 V5 b0 l        'labels' => array(
, P5 Y/ y/ l7 V) {! u) j            'name' => '公告',- u( O" j" g8 W
            'singular_name' => '公告'  a1 b/ M2 |1 q' @* Y
        ),. S7 a$ h& f+ D/ V! C4 S
        'public' => true,
6 m  y: e8 [" O" M" Y# N6 _8 w* d5 x        'has_archive' => true,
& {3 U7 K9 v  v8 l) p' C( `        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),5 G8 J! F! C+ d/ M3 M
        'taxonomies' => array('category', 'post_tag'),
  o& T6 [3 a- e        'menu_icon' => 'dashicons-megaphone',0 ~& H0 l. C1 s6 V' l7 p
        'menu_position' => 5,: s$ N2 E) f8 u2 ^# y
        'rewrite' => array('slug' => 'site-wide-notices')+ O1 G9 f! }9 W4 A0 T2 j8 J2 `) k* @
    );
" O- L% u3 x& G0 y! v    register_post_type('site-wide-notices', $args);7 n+ B+ R) w0 E) X  s# ?
}/ c3 b1 C" ]; ~( G# z
add_action('init', 'create_custom_post_type');6 O  Z; f& W3 k- [) t0 `
```/ g" y; j' L$ I4 \) q! N
. }5 r( I- _5 ^
在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。
) o  V' p* z9 M( \' B, b$ K' ?3 U: ]% j2 p7 f: S8 A+ c# Y" P
2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。( F9 `$ d: j- o& t

7 G$ ~+ {) X1 H3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:
! K; }; w9 q2 ]8 P% d2 M1 Q$ |9 v0 x
```
$ ^3 s0 d8 T% u3 C4 M* `$args = array(
$ R0 I: D: o+ {0 }& x+ m    'posts_per_page' => 3, // 显示的公告数量
% o) i3 D0 l9 p    'post_type' => 'site-wide-notices', // 公告文章类型
$ K- l5 ]8 z! W7 {    'post_status' => 'publish', // 公告状态
# b8 z  L+ X" \# j; \5 y    'order' => 'DESC' // 排序方式. L9 u  l7 l3 z5 Y  a5 n
);- P0 z8 D+ m3 i+ P8 O2 @
, j. H7 m' \+ N: N. E
$notices = new WP_Query($args);9 C. t' b$ v  R. ]
if ($notices->have_posts()) :
1 l$ W# g3 e) o: ?( C! s, A& X  W    while ($notices->have_posts()) : $notices->the_post(); ?>
0 |7 t$ G; m% I& g, P& |' a  o: T        <div class="notice">7 w1 x; `1 Y5 I/ C% ~. a3 z
            <h3><?php the_title(); ?></h3>
# E% _2 A0 R6 d2 n" v" T            <div class="notice-content"><?php the_content(); ?></div>
3 G) k4 Y7 R8 t0 D        </div>/ e- Z3 b- s; l7 W, j
    <?php endwhile;. e3 c4 T; p% x! M  U
else :
$ b' o/ e  Z% ]9 g, J2 ]/ s6 [    echo "暂无公告";
5 r! X5 b3 _0 Jendif;
. y' y5 c; M3 b: @, I% ]; mwp_reset_query();
% x* z1 P0 w( E$ Q  V2 V```( S) ?, L/ C, L" L

4 I: y( y- D4 F这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。( d- C3 r9 |- e

% r- r5 w9 m# B2 y以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

341

主题

541

回帖

3575

积分

管理员

积分
3575
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?; D7 M, o' \6 ^

) _8 v. f; M& r如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。
7 K! i% [8 h/ H) l' b' z: q
1 o1 o. U8 ^% M! I% t6 ^# H9 t* p以下是创建自定义插件的步骤:
" ^( D1 H  k  s- x" X9 k6 A* O0 N! x+ F
1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:$ Z0 V5 q; Q# }6 v( A1 f) C/ n
/ r& G5 v: T# z' B1 P1 v% ~/ T+ w2 F
   ```
6 [9 S3 y8 N( d. ]! {+ J$ m/ ~   <?php: A9 c3 ^5 }3 F6 a, e1 M
   /*9 p3 z9 k8 W1 X, v, W1 V
   Plugin Name: Site Wide Notices Plugin; {* D+ ?" `$ D# \  W% q6 f  N
   Description: Adds a new custom post type for site-wide notices.6 y/ n% _/ A+ K0 {0 r9 j
   Version: 1.0* [! D; S6 V8 Q3 r! f5 v0 b
   Author: Your Name& ?8 M& [% s% O  e5 h4 V
   Author URI: http://example.com
* U% i; X) B: q4 R   */
' @# b1 Z% |0 W8 B8 F' j
9 J. m5 D$ k6 W2 F0 j& d7 X; x3 j% J   // Add plugin code here...
: i" x& t3 s9 U& o6 X7 h0 B5 `   ```
% E- H8 e0 j* `0 G2 G+ Z, C
* s0 d0 z& Y* L0 N; w2 G   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。1 i2 c/ e. p* m6 C
+ ^2 a, {2 I: y' q( w! y/ w  \, E
2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:
" \# w; `3 \2 j* d" c3 y2 i, F
+ u4 a$ B/ B/ s' E- }% n   ```3 Y! I9 o% n4 ?7 _. }
   add_action('init', 'create_custom_post_type');! P5 I, p; O/ q+ A; h. N
   function create_custom_post_type() {/ F0 f/ b8 G9 l# k) ]- |8 M3 i
      $labels = array(
) r5 k( T4 [! t  N( g! Y' F          'name' => 'Site Wide Notices',# ]8 p* G( A2 M7 {# Y
          'singular_name' => 'Site Wide Notice',2 d; {& ?8 @0 B
          'add_new' => 'Add New',( s# [* h7 h! Y# G/ D. Y8 V" P
          'add_new_item' => 'Add New Site Wide Notice',
# ]- `7 e) R4 s* \4 }' p1 H- Y, Y          'edit_item' => 'Edit Site Wide Notice',2 H0 m! s/ @! G0 M# _7 N4 r
          'new_item' => 'New Site Wide Notice',
( O8 ~) a! a) h: @' {" p- i& |4 L          'view_item' => 'View Site Wide Notice',
7 ~% h& q- x, L  b          'search_items' => 'Search Site Wide Notices',. C% k  P/ G  v, j5 j$ x
          'not_found' => 'No site-wide notices found',
. V3 M- A1 S' I; K# c6 e          'not_found_in_trash' => 'No site-wide notices found in trash'/ ~+ P! y5 V) ^7 C! b
      );
2 @6 z7 x5 F: }- c1 ]% g" j0 r2 X, G2 [
      $args = array(0 P/ o  D3 ]* F" y
          'labels' => $labels,! d" u7 n1 w' b8 e( L2 }5 j/ L6 n" d
          'public' => true,) i) H6 V) E5 M( }, _. J
          'has_archive' => true,
, @6 |& a& m: [0 y2 K+ `2 s/ B          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),, e3 q# k$ f2 q' O1 x& ]
          'taxonomies' => array('category', 'post_tag'),
* r& \: e8 A6 \& I4 _  g% ?          'menu_icon' => 'dashicons-megaphone',
2 l8 s" \- }! U9 J9 Q  H1 L& M          'menu_position' => 5,1 S! W$ j& r& e# K4 l/ M" a8 z( G
          'rewrite' => array('slug' => 'site-wide-notices')
" u- N/ e6 ^; _- r* y7 a  g: n      );
0 b9 V' g  c4 _# M( n1 L9 R! p" i# M. Q2 J
      register_post_type('site-wide-notices', $args);# j' B3 j. z" }
   }3 S0 I8 t' Y. `/ U  V
   ```
+ `+ \( u2 m" q9 u- x% S
# j! d. j. d3 ~5 y   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。
! W1 Z9 K0 `8 m( W. w4 d* ^" V" f, e4 ?- Z$ l  z
3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:
0 f; q3 k. _$ i. \& }; |" N" Y) V- k: W7 ?3 O5 k
   ```
/ ~, h/ V5 Y. j! e8 B  V   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');
% ]+ S8 \! t- T4 z5 y  T   function add_site_wide_notices_boxes() {" Y  u* P& p3 \, ]
      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');4 m$ R% A- j5 l2 w$ [
   }9 e3 {6 L7 _" _$ X% o+ m+ X7 p
- D6 |' p& e' Z' @
   function notice_details_meta_box($post) {
( \& G, R  A! m. Y' G1 m      wp_nonce_field(basename(__FILE__), 'notices_nonce');# k' M5 W2 \7 j
      $notice_title = get_post_meta($post->ID, 'notice_title', true);) T+ A/ V2 M) \6 j# [4 |$ g. w
      $notice_content = get_post_meta($post->ID, 'notice_content', true);
' `) {" Z4 N2 j. E0 I/ {      ?>
# f# S1 E& O/ U; A" D/ ]3 w      <p>
, ]% z* @; H  Z          <label for="notice-title">Notice Title</label><br>
# Y" l: p3 ?% x$ ^3 ^7 @          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">
9 e  }$ Z& ?' e5 C3 J2 t      </p>
1 j+ ~( ~. [( d, R1 n      <p>2 [$ y- {$ E- n. O* S% O1 v& s! a
          <label for="notice-content">Notice Content</label><br>4 A% g+ W$ k4 B" n5 @$ @
          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>. Q$ g6 r' T& n( l
      </p>
4 q$ y9 C; a- m0 u4 y" ]      <?php9 a. s/ g" z. X, W7 n
   }
! f% z! S. j! v% }+ _4 e! D" E- A' S4 n7 u' ~# p4 ^8 q+ U
   add_action('save_post', 'save_site_wide_notice_meta_box');
1 w* r+ `$ p% y$ e   function save_site_wide_notice_meta_box($post_id) {1 M) \1 _6 ]/ o
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))
( K. Q4 O5 g$ k5 f  d         return;# P' C& _' u9 v0 I( z$ r, L
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)
$ J4 V. b$ i- f# r         return;- g) c. g0 {2 }4 E) W& e7 l

8 F, p* e, ]3 e5 d0 @2 [9 @  }2 s      if (isset($_POST['notice_title'])) {' N; ?# B! I/ @( x9 U8 O. _' N* S
          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));; b$ D% u, t! I& H4 Q
      }3 ]+ n) v; E& z" r! d( l
      if (isset($_POST['notice_content'])) {! y& n8 P1 W0 g2 v8 Q) \9 U
          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));0 c; ]8 f8 Y5 x2 b) J
      }* T& X# Z( j' q: w
   }
: ^" w4 i% J& A( B   ```) Y3 L, R; m( W+ d) z$ _- p
* I# m# ~, C9 Y  o
   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。: h  ], _4 d% N8 {  W& z: c

! p3 m4 ]0 y$ T( g3 H, Z4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:
2 o, d- R6 @8 D$ V+ H2 X
4 L- |  Q8 @7 N! B   ```
1 U7 h( q# z  l0 ~1 J' A' _$ I3 p   $args = array($ R& ]- w% C! ?' U. }
      'post_type' => 'site-wide-notices',) B' d5 @# V- A5 U8 [* B" Z! [
      'posts_per_page' => 3,
) E/ I1 y$ C+ L7 B4 [      'order' => 'DESC',
8 G* @0 c0 v3 Q" F      'orderby' => 'date'
# W. p( T# n1 k% w' h. `   );
2 p' h% {# I1 s! y0 X7 [2 @   $query = new WP_Query($args);( M$ E7 E; @  T, \! m& g
   if ($query->have_posts()) :/ v- Q+ M) N' ]
      while ($query->have_posts()) : $query->the_post(); ?>7 l% a+ p. K. ^9 {+ s) L
          <div class="notice">$ c& R- E( k0 K
              <h3><?php the_title(); ?></h3>
7 D" Y7 R. X+ N              <div class="notice-content"><?php the_content(); ?></div>
6 `) P3 E7 v" J( o& ~6 ^, C/ {          </div>
; @4 a% ?, Q( `7 x( J% V      <?php endwhile;4 E: B# h% Z$ {! i( R6 c1 O
      wp_reset_postdata();
4 X2 F. ^3 y5 a3 h' Y9 I7 h   endif;
/ [0 I/ \+ ?  W& ?" n8 m! Z$ A   ```0 Y- R3 M5 `/ }  N, V- Q, c' Q
; T8 x/ e' x' C
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-25 14:03 , Processed in 0.016401 second(s), 2 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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