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

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

[复制链接]

340

主题

529

回帖

3528

积分

管理员

积分
3528
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:
8 `: O: g2 Z+ v; I, X. l- E  o7 q. ^, c5 X: I1 ~$ f
1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。# o$ h  S% U& W4 W

0 Q) f% F' p9 J2 c2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。  P9 ?# `' U+ @# k/ h9 ~1 k
) Y' @5 t' y3 P4 o8 U. c! ^1 i
3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。- d8 u* P; G' e5 c  }$ `; w

+ o$ H6 _& w  o* ~% D4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。
1 o/ ?$ @% n% p! @) B* R% t0 O0 }' g/ @. ~" J, a' u
注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

340

主题

529

回帖

3528

积分

管理员

积分
3528
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?
& P: a0 @5 I* u% ~4 {# d8 B, I3 n. F: b; Z) R6 w: j9 Y4 i( y7 F
如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:* J& j" F( E1 b: l% ]
0 q: w& L: {) n' Y9 U0 F  R  e
1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:9 S( P9 Z  D$ l
( a; J4 Z$ }1 `3 A" v. U/ X% y
   ```
8 ~3 b6 S  j& O. S8 G! k. N% w   add_menu_page(# r  l3 _8 ?4 n6 V" ~/ [
       '全站公告',
4 d, o/ o6 o" @! B       '全站公告',
, g" D4 ?$ x: x) b2 t       'manage_options', //需要的用户权限& a: S5 q; y8 g7 b; x0 l+ D
       'site-wide-notice', //后台页面的 slug6 P$ `  F4 z" X9 X, q  I
       'render_site_wide_notice_page', //用于渲染后台页面内容的函数
5 d; \9 J" j0 `* C       'dashicons-megaphone', //用于显示在菜单中的图标
/ T0 H' I" z( ^       30 //菜单项的位置9 U- d/ @' D/ c4 t8 G4 w
   );
8 [. l! r9 c) f) r. W   ```
0 `6 j7 w" l- T
) E( d  p7 F. W' S- Z   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。
2 v  ]& J  v5 C4 n- J1 j0 P
- \% A5 T) U' O2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:( C- N: v' R& W6 K
/ y) r: g# I# a5 Q1 h2 _5 m# M  @
   ```
' _; x) ~: |2 H' W' X' }- s+ `   function render_site_wide_notice_page() {0 z* b+ U9 p; W! i
      // 渲染后台页面内容, k! A" O: H+ K0 |, I- m4 N5 l
      echo '<div class="wrap">' @+ {! G% O, V) `) W( |
          <h2>全站公告</h2>
0 b* y5 {4 Q1 x( d& B          <form method="post" action="">. n, y% \! @1 K, g3 ^" t1 U
              <label for="title">公告标题:</label>7 p, F, o! Q/ w1 A3 Y( v/ D
              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>' j/ }  Z8 d% Y6 A/ R
              <label for="content">公告内容:</label>
+ O! t  Y# X# B- H) M! Q, d7 z9 R              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>3 E/ C* V) Y  K* L, v0 {
              <input type="submit" name="submit" value="保存设置">7 E  S  K8 s6 h1 U0 J: u3 D! Y7 Q
          </form>
, V# h+ V" L9 V0 t6 Z7 r$ q4 }# f      </div>';
$ n! p# B9 X0 h# N4 J4 a
- i8 j( O, G8 G) n3 I' `) h      // 处理表单数据
" ]& I1 d- t3 p8 u" X% c- |1 W      if (isset($_POST['submit'])) {
) Z3 r) e2 N8 i. R* E' M) ~          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));! N" O: d* Q" _& X7 g3 z
          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));
" z& M# p% m4 i      }4 e5 Q8 P% y5 F- ?5 f/ g
   }
3 u6 j' d; W0 t3 U3 P8 P- \. Z   ```6 f5 l7 Y0 B, M8 U* u% ~! P

6 V+ }5 o3 m( e. a3 r2 ~   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。
( t' h! E' b1 z; [- W7 W0 N' y2 ^# y8 i
3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:+ F9 b6 [, S3 f- U

0 `! o" \  t0 s* z6 @   ```8 P! T& B1 E+ W
   <?php
1 g6 b2 X6 _: y" ^   $site_wide_notice_title = get_option('site_wide_notice_title');  A3 r) I# q* f8 f
   $site_wide_notice_content = get_option('site_wide_notice_content');
9 U! r4 a7 k/ i3 x9 r- k, d7 j   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {
7 H7 g8 H) H* N- Q1 E8 d- ]       echo '<div class="site-wide-notice">';
& k0 a3 `- F3 F  X& ~       if (!empty($site_wide_notice_title)) {
; w: I1 r& @" T6 b; _, K, e           echo '<h3>'.$site_wide_notice_title.'</h3>';
0 j5 b. C0 a7 y: g- V8 u1 X       }
& i% s* h+ b" ]" k' Z9 ?' d       if (!empty($site_wide_notice_content)) {; B; X# f" P/ [0 h
           echo '<p>'.$site_wide_notice_content.'</p>';
4 S! R; P" `4 v7 A       }
0 F$ M8 q  L# \0 [! ^       echo '</div>';8 \- q: _$ r, k# o3 z
   }
  D" Y( p9 g! v$ f+ M% p- k   ?>
0 M3 f% X( \: w   ```
( D4 p8 a, }8 q. `
. B0 Z% J4 k, j7 ~) t2 c2 `   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。
% M/ c+ N5 }- l! K* q6 i$ s  p! Z* r
请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

340

主题

529

回帖

3528

积分

管理员

积分
3528
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?
8 W, Z+ }5 ?4 T* j. o: {0 }' E, O. g" m5 B& j
您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:/ ^# ]* s+ E6 \  Q5 d. e3 G, r
9 H  x. b( s0 j5 o# R: ]7 w
1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:
% `6 j; y1 u" P: s! ^  i% g: g
, g3 ~# W3 _/ S" [9 y! L' r```
$ e4 h3 J3 D' {* c; cfunction create_custom_post_type() {
( T$ r- s4 L: g7 C  j* m1 g    $args = array(0 c% R( Y" j! O3 _+ h( T! N
        'labels' => array(
4 e4 Q0 D4 n" i- A: i3 \            'name' => '公告',. ?! b9 |: d- d* S6 X7 \8 s7 N
            'singular_name' => '公告'/ U  [( V4 }1 s% }6 K' E
        ),
( ?' N7 ]* \& A. \% r        'public' => true,
% b- h8 ^8 `# t3 V3 N) f. q. v, M5 Z        'has_archive' => true,# p0 o: c/ t$ c: u
        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),7 `2 @" t' O1 j$ h6 j7 [% T
        'taxonomies' => array('category', 'post_tag'),
: q! h/ v: a, o% R9 ?        'menu_icon' => 'dashicons-megaphone',
. \. u$ Y/ X: }        'menu_position' => 5,4 i+ }( q, \4 t! A6 B( X* r
        'rewrite' => array('slug' => 'site-wide-notices')
( e7 ?. c4 e5 |: a    );" C8 i4 `( _! s8 {/ x
    register_post_type('site-wide-notices', $args);% D- w- E( `2 X6 t
}" t: [# ~! v$ V( J! b
add_action('init', 'create_custom_post_type');) J2 Z# `" o2 {2 f. f& Y
```# S0 N- s$ _8 Z
, _3 m) x0 \9 X  d- U- ?
在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。
" y$ {; S8 ^$ O( F  V3 ]9 Q0 t
0 ^! M4 X  ?& B* ?  I2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。
) \+ Q8 u7 ?1 N7 I# s- z; R) l; g8 q+ ^0 K) u) F4 S4 f2 I
3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:* r9 J* t, i( Q( N( ~* _3 `
2 W& v1 I- V3 U
```- ?$ }7 X( h' h2 C+ n. |# D
$args = array(
2 F% r3 o- n% u8 t- m/ `    'posts_per_page' => 3, // 显示的公告数量) e  Y2 A% l4 V' f$ q
    'post_type' => 'site-wide-notices', // 公告文章类型9 C5 q% [" s' L( j" T" ~
    'post_status' => 'publish', // 公告状态
2 ^5 s" n/ ]* n7 j( r1 k$ h' J: V* _    'order' => 'DESC' // 排序方式3 D6 q# f& U" X. X& P; w
);1 ~0 t; E7 ]  ?5 |4 ]  N& q" u8 s
; a/ \/ P5 M. ]# X6 Y& e
$notices = new WP_Query($args);7 o  |" P4 ^( V  |
if ($notices->have_posts()) :
: u2 r2 X0 Q; m! }1 I' O/ h    while ($notices->have_posts()) : $notices->the_post(); ?>0 d, n: Y* N) |: k7 `
        <div class="notice">5 A. F! e$ ^+ {, G- f# w
            <h3><?php the_title(); ?></h3>
& y$ x9 f" J$ M' c0 M            <div class="notice-content"><?php the_content(); ?></div>- w/ I, l. Z2 C
        </div>
9 n+ ]: X! ^1 c* r    <?php endwhile;
4 d0 D2 c9 L! V+ `" D- Celse :
. G5 B& ^; t7 d; y, \: `5 U    echo "暂无公告";
( }; D0 ]- B/ M( S3 A4 Rendif;
! W" h7 K1 N) i, K. V$ gwp_reset_query();
2 Y( Q, s& D% t```
: t, u+ [/ T8 n9 }, g) H+ |* s3 E3 X. ^) |3 W, k# }2 `0 K
这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。
$ e% o7 a7 y4 e+ Y3 b) C- r" C5 ?3 X8 b' n
以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

340

主题

529

回帖

3528

积分

管理员

积分
3528
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?1 W( b7 Y' p8 d% D
2 U2 i, V/ F3 \2 R
如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。) }1 L* z! u. _/ V$ E

( ?2 f- C* F, {& w- c* ^* u以下是创建自定义插件的步骤:( O; J$ G5 B4 z! J' N7 r9 F0 N

) T; Y& {- E7 _, U5 ~* D, N1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:% t8 K9 a# b1 z, g$ \
7 ?2 n: ]* c2 I
   ```
; Y3 y% r5 _+ i1 F3 h" t( U; D   <?php& q2 N+ E/ L  q/ s* z+ W
   /*2 D( I: T3 g, @& U$ q
   Plugin Name: Site Wide Notices Plugin
  R4 s) ~1 T0 ~* h- k2 H   Description: Adds a new custom post type for site-wide notices.
: i3 g, T3 B4 P6 x: Z' o* M   Version: 1.0. d9 [- o; p- G% v4 g8 s" z
   Author: Your Name
. z: [! e8 O: P9 C, q   Author URI: http://example.com
$ E; o) e) S& a- N. m) O, R   */% x: M. _, d+ C( v, Q& r

$ k% }# m- |8 ~+ B   // Add plugin code here...
% Y' O/ C  g! E/ b: c6 A: {* b  [   ```9 r7 I3 [) Q. e* |! p3 A
7 \, ]- @" v/ Z* }0 I, ]
   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。
+ E" U! H- a! g1 u' b6 Q( R) A3 ?" h  Y- V/ f3 n9 n. h& T
2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:& T" `  I4 v9 ]; X3 m. f
' {. l$ X: p6 V8 x0 b/ J- P0 Z
   ```) v5 Z; \2 F6 n, P
   add_action('init', 'create_custom_post_type');4 m- C4 B6 e2 l7 Y; P
   function create_custom_post_type() {
' U3 v& b. _0 W: y# v& H      $labels = array(
; C) V3 y5 @1 Y! {8 I" b' z( ^          'name' => 'Site Wide Notices',) U. e3 b6 b8 T9 V- K6 r' m9 C4 }
          'singular_name' => 'Site Wide Notice',  b2 j4 f. e4 j! U  P
          'add_new' => 'Add New',. J' h* _- \$ C  G1 w
          'add_new_item' => 'Add New Site Wide Notice',
- Y; K6 T+ o# j. Q0 P9 w          'edit_item' => 'Edit Site Wide Notice',8 Z. Z, }1 C+ a
          'new_item' => 'New Site Wide Notice',  [) B8 W( G& d7 H3 Q; {
          'view_item' => 'View Site Wide Notice',! @2 m5 p9 O3 H1 N. }, D; R& x- ], [
          'search_items' => 'Search Site Wide Notices',
0 w. F  Q- R$ u          'not_found' => 'No site-wide notices found',
) v5 j$ O9 X2 h          'not_found_in_trash' => 'No site-wide notices found in trash'
! J% {6 Y# W0 U8 W      );
& e# W8 ?, U7 k4 W5 o$ e; s5 s# s2 g+ m% y" f) X. X4 E; ]
      $args = array(3 @  w1 K0 P. F4 D7 s/ `
          'labels' => $labels,2 w- r- n9 `) f
          'public' => true,7 N1 w! d, ~' l( x9 Y2 H' S* i
          'has_archive' => true,
- Y! p5 D& A- x3 p0 ]0 n; s2 Z          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),- F5 q( x- s; d& b; t
          'taxonomies' => array('category', 'post_tag'),
+ ^0 f6 f* x) a2 `          'menu_icon' => 'dashicons-megaphone',
+ Q# z1 K6 @4 B& h5 q3 N/ N          'menu_position' => 5,
+ x8 |- g  m5 G: n, z          'rewrite' => array('slug' => 'site-wide-notices')8 m; s; _7 P1 v5 }
      );% @: ?& B# o, H/ X$ A

; x0 v. v0 \) C0 }# M0 I' l      register_post_type('site-wide-notices', $args);" g( B) s5 U1 s: q" Z  {" u9 M
   }
: z7 A9 r2 @, [1 Z2 S   ```
: ^7 n, ?) H2 x/ \3 L3 @. a' f% ~2 j' i1 Z: ^3 t  f5 `! D
   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。
" c+ e; z1 u) c9 Z: _5 B+ r& w: p) t, i/ c0 o# C) q4 _: }
3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:& b+ I1 Q- z4 O6 m1 h: q

) B  N+ e' ^& e% F6 u1 E   ```
5 T+ `$ C: L" ~  x, j1 M7 d' X4 L   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');  L$ ?- o# Q! }  ^; U
   function add_site_wide_notices_boxes() {) f& V1 ]+ }+ X; \
      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');
6 d( ^8 X) `/ Z& E" E1 d( B: H   }
; M4 a0 Q$ d3 B& P% D* Q) v  ?
1 m1 F& z! g! i) b9 g   function notice_details_meta_box($post) {# G# W* Y* r0 C7 W3 b
      wp_nonce_field(basename(__FILE__), 'notices_nonce');
, R; v9 p2 C! K; [      $notice_title = get_post_meta($post->ID, 'notice_title', true);
7 e% J5 S5 C! R4 k. ?      $notice_content = get_post_meta($post->ID, 'notice_content', true);
1 S: V# r7 d" Q9 |      ?>7 C& L# a& E; F& C6 j
      <p>% f" h9 u- Q) [2 `
          <label for="notice-title">Notice Title</label><br>% o. S, C: }$ V( w' n' z
          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">; I/ v& X+ v$ L5 j) k5 w
      </p>* L1 L( j! y( T) a
      <p>" C# v" ~2 S# X) \0 w
          <label for="notice-content">Notice Content</label><br>
& J& D! R) H% ]          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>
1 o: f. V0 ]2 ?! k: R4 S  y      </p>
# S; b3 @* {8 d" P) G      <?php. d, g' J6 g# \; }1 |  l! q7 X! F
   }
( |/ J8 a8 {9 ?" U
/ g4 L% y/ Z! z& H* ^  j   add_action('save_post', 'save_site_wide_notice_meta_box');, y- o% B0 g8 Q# n) p: A) b
   function save_site_wide_notice_meta_box($post_id) {4 f8 [3 f, A5 {! u
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))/ \: D2 {- G7 z6 t, x# N8 i. Y5 f
         return;, ^$ C. g! ]7 Y# P
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)
1 K$ [) i, B1 E' |8 G         return;
3 U( C2 l4 k0 u1 a8 Z- e+ O
1 Z, O. C$ Y- {8 `      if (isset($_POST['notice_title'])) {& e& N1 y3 a9 n3 m  y0 I3 @
          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));0 K) a7 Z5 }- s( Z* @
      }& X  E, [; ?" {! c# O. q1 x
      if (isset($_POST['notice_content'])) {7 Q' l& y! j' E
          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));9 Y7 a; g. o, [5 a7 C
      }
/ I( x$ o5 |; t9 p: n   }
2 x  Y" K6 i( ^3 Z; G   ```- G, }* E$ l0 p* p" P/ H6 p
7 j/ K' Q* ^' T% ^9 z4 z' [. R3 }
   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。
# b4 U" ~% c- e0 N6 s3 i  x" p5 _6 R7 P- a4 O) P. P6 n
4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:; q( n' n& k7 e+ O1 M' c

3 @$ |; E+ O0 Q9 I- ^* q' e   ```9 S: v) x0 e+ z2 Z/ P
   $args = array($ G6 ?4 b( ~) T
      'post_type' => 'site-wide-notices',
( S5 C; C4 j& o) A" ?+ H1 j      'posts_per_page' => 3,- l# }* }" t- y8 ]6 i. M
      'order' => 'DESC',
$ m) P7 v- T. Q& s6 e8 d      'orderby' => 'date'( Y: G. _, t- M6 o, E/ g
   );
+ T, X  i: d/ `' |4 A   $query = new WP_Query($args);
% X$ l- ~1 H. Q  P$ ^   if ($query->have_posts()) :/ p3 t+ T; e9 {; X
      while ($query->have_posts()) : $query->the_post(); ?>
( w+ v; Y, P1 F: W/ F" F0 J, o          <div class="notice">& S) D1 `! u! N+ {2 T; p3 M
              <h3><?php the_title(); ?></h3>
- F' L8 C9 \3 M7 F4 l+ A6 `: b              <div class="notice-content"><?php the_content(); ?></div>. u  n( [% S9 C; j- w: w/ K8 p
          </div>
% R- _% {9 Q+ u$ \, h      <?php endwhile;
) D3 z% G! x; [0 }6 b9 a3 ^      wp_reset_postdata();: U+ G, G9 [9 m' a) O4 U
   endif;8 j- E9 {( I8 t1 S
   ```
  c- ~8 {, r& y/ _  f9 B1 ^2 t" ], B  h: L2 s. T5 D2 G
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-19 07:18 , Processed in 0.019186 second(s), 3 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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