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

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

[复制链接]

346

主题

559

回帖

3656

积分

管理员

积分
3656
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:6 }5 ?2 T# F4 N" W2 ^* K

" E. t5 a) j' N' }. _1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。
/ a5 e8 ?- j3 A1 S6 o
  \1 W! d! C7 X2 l) p6 n# B2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。# t, p& z( S7 ~3 \8 g
, K3 p% c5 p  M. ^, s6 `: ^3 M
3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。. }2 Q. f- G1 A0 X$ }* m; ?' B

7 g' j( D! J- r  A  f; v; k4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。
9 H. w. W, t" o* k# Q9 c/ ^! t9 x/ g' c
注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

346

主题

559

回帖

3656

积分

管理员

积分
3656
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?% |% _# u. d" J

8 B2 _7 ]2 c( K0 z如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:6 L/ n2 N9 b; t- H, y

9 {' u9 O9 R8 h$ O1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:+ H) @3 u3 A) |7 X
1 P, J9 F  W1 M* ]+ F
   ```
4 b& h  p1 G7 N# c7 z1 I   add_menu_page(5 ~; D% \+ Q. D% W( b
       '全站公告'," l" h$ [9 a& Q: n, d
       '全站公告',# F! J6 I9 U* K1 d* O9 }4 L. A1 h
       'manage_options', //需要的用户权限
' k* _% d5 M3 g6 b9 U0 E       'site-wide-notice', //后台页面的 slug: m9 `# \* B: S& ^2 M/ L
       'render_site_wide_notice_page', //用于渲染后台页面内容的函数7 U  [2 S; U+ k  l' O
       'dashicons-megaphone', //用于显示在菜单中的图标9 |! k7 K3 J% V
       30 //菜单项的位置6 n- i9 e9 A8 W0 |. W/ t, F1 D* v4 r
   );1 R. _7 O% `6 S# q
   ```! M" G$ M$ a; v4 Q9 K
0 W9 `2 c4 A4 \% d9 _
   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。( D+ C3 A: E, G1 i

3 ]& T& @$ s' M, Q# V7 D! i3 F6 y" o2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:, L& i' j0 H) e( e) m, e! F

' G8 g% s3 ?  U+ R' g) ?   ```
* f( Q6 u1 `$ [! I' |, l   function render_site_wide_notice_page() {
5 B8 Y% `3 m' O0 m1 M& L      // 渲染后台页面内容3 v' V7 m* {# L8 t2 z/ ]
      echo '<div class="wrap">" v" Z1 t4 S/ Y4 E* [% k/ Y
          <h2>全站公告</h2>
: a3 r) h$ W& A1 O7 |          <form method="post" action="">9 b/ ?9 C  B$ |8 Q  t
              <label for="title">公告标题:</label>+ E; f8 q  E1 M; j- N: D6 |
              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>" ~, `9 Q3 t( c; R  V
              <label for="content">公告内容:</label>
2 ?5 Y( j- j6 q4 D+ @8 c  S& Z. c              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>/ Z6 @- `6 A/ U0 V* L7 V% H6 d2 y. z6 x
              <input type="submit" name="submit" value="保存设置">2 [: [* L; o1 J/ \! f6 I4 P  T
          </form>2 |' Q8 B7 g/ E
      </div>';
: k7 x7 {4 J) M4 I+ X$ A) E
' u3 g$ h4 h  b      // 处理表单数据, o# Q5 ]7 n$ Y5 }- B3 Z
      if (isset($_POST['submit'])) {
' h# T2 _( W, o* m' P/ F- E- K: P          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));. j' R; n) v9 Q5 A) J
          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));2 E8 F6 e" G. X
      }
! p: h$ X; \# d   }
0 o+ b! b; h; L) P& Q5 Z/ s   ```
7 m- a% q! @) {; a2 K" m
8 a' }7 q$ y0 K# v9 S) y' Q4 b& \   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。
5 N& R2 N9 ]7 w- `# `+ |1 O  _* D! v
3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:
( t% V6 y; q8 A$ Q# Z! i
6 k% e! \& s% ]7 ~/ c( ~7 k& }" ^4 S   ```
6 v8 Q! ~: X/ B* X4 ]7 k, {& J* m) i   <?php
7 i7 }1 ^! V, z1 Q% y3 p7 H. ?   $site_wide_notice_title = get_option('site_wide_notice_title');! \6 C% r% W; e3 c! C
   $site_wide_notice_content = get_option('site_wide_notice_content');. u0 S4 O( U/ M( S
   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {
/ J. a$ M( K& o       echo '<div class="site-wide-notice">';, v+ P/ ^+ c- r4 @
       if (!empty($site_wide_notice_title)) {
  o1 y9 K* H% K$ X( D, @" {1 Z# t           echo '<h3>'.$site_wide_notice_title.'</h3>';
- Y" c% N2 X( ^8 q, d  s       }% |: j0 L" y! Q+ A
       if (!empty($site_wide_notice_content)) {
" y9 Y4 _4 f1 h% ?           echo '<p>'.$site_wide_notice_content.'</p>';  u8 M" f7 u+ ]) n8 Q9 P- O
       }
0 w4 n9 S6 v0 T  t0 V       echo '</div>';
+ l+ [) J0 W9 l. N3 g/ @2 }   }
# u, c9 {" ^8 l7 m0 x   ?>
7 p) A7 b& Y( W; L; L1 v   ```, ]4 Z* c; g& t# r
" X5 }2 `% H( y# R+ Z- Y# h, W3 V; d+ c
   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。
3 J5 _2 [+ H# F; _  w1 U7 {4 t$ I) G/ ~- _# ?2 B+ _3 ~4 W
请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

346

主题

559

回帖

3656

积分

管理员

积分
3656
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?; Q: d( F9 X5 Q: U

. f' w2 d0 Q! c( A您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:
! p$ Q- v% h; g/ l8 e+ H% J( d7 q' v
1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:$ c& D+ ~# @/ k( \

& m. A1 l  D4 o. v1 V/ u" A& F```
; \  Y0 N1 m0 U% Q2 V* lfunction create_custom_post_type() {' n$ q' x' d& I% ~6 P$ h4 A/ l% C
    $args = array(
3 r( L% i& b, ~        'labels' => array($ N1 C% l7 [! [, s- q7 M; c
            'name' => '公告',
  }4 ^  \1 i1 n3 v4 H            'singular_name' => '公告': Y7 l  v# b7 h& V
        ),
5 \9 `. V& I- O1 c5 R6 [  B. ?        'public' => true,- {6 c2 c' X" m( M- i& Y& s/ D7 r! }
        'has_archive' => true,5 \1 V  ?# Q" o+ w
        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
. V2 Q% z8 U$ N  t) z; A        'taxonomies' => array('category', 'post_tag'),
3 C9 x1 w/ n+ y' i( g$ S        'menu_icon' => 'dashicons-megaphone',: g5 Z0 B' K! X- b! E( l3 [
        'menu_position' => 5,' z: U; U1 m1 D4 M
        'rewrite' => array('slug' => 'site-wide-notices')( G5 r5 c5 t, ]% g, {! {) R
    );2 f3 X: E5 M4 ]# }, w
    register_post_type('site-wide-notices', $args);
) B' `) R& i7 l4 t1 c, j/ ]0 F. x}. @- Y" G* p; A+ t! |2 f
add_action('init', 'create_custom_post_type');
1 a/ S' j8 g5 Q4 I( w3 I```' L# g1 E+ ^6 s' I4 x
  R" ]* @, K# G$ W- Z! I* [
在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。3 Y. b3 Q# _2 a3 w- T% s5 I

& s8 ~2 Y2 l% R4 @2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。
" {9 h0 U! B0 D/ {5 j1 [- q
7 k/ W5 M; N# Y1 N4 Y2 r3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:) W/ |( ^/ T0 V& e

; r* L4 p" e$ w/ \  Z' a& ?9 ?```% f# I4 N# b9 D) _
$args = array(
6 o' T& s2 P6 j  {    'posts_per_page' => 3, // 显示的公告数量
) S% P- }+ S, _" F    'post_type' => 'site-wide-notices', // 公告文章类型0 \+ @# m5 E- a! u9 E
    'post_status' => 'publish', // 公告状态
, @3 L) R5 T" g! z" r6 Q7 p    'order' => 'DESC' // 排序方式
) @' |# V6 b  f% p, g# I);1 D2 }  q6 M' [$ {

6 S# w# i: q! Q3 F0 Y% W$notices = new WP_Query($args);0 T! W; o0 v! t# M: S
if ($notices->have_posts()) :
3 d$ F; M, ~5 ^* f    while ($notices->have_posts()) : $notices->the_post(); ?>4 \4 Z' L0 c; u
        <div class="notice">
# N1 C7 o$ N  [$ @% z  g# F            <h3><?php the_title(); ?></h3>7 [5 ^' K* X) u" v' A8 F
            <div class="notice-content"><?php the_content(); ?></div>8 P$ Q2 f( O/ u+ {
        </div>
7 @- t. y$ H$ ^" r5 j2 w, A1 o    <?php endwhile;
1 f0 z4 g! ]" P: \else :
3 `6 F9 ~1 G; x! r! c7 @* t    echo "暂无公告";
8 ?( O1 M- t* Z, m, ?( w/ ~endif;
) L+ W, }' X, Z4 I3 }9 lwp_reset_query();7 i: _0 T7 r5 `: y
```' Q, ]/ [5 L* f7 I# R9 N5 P+ b3 [

: @7 K- N. R7 n/ ]# }2 E8 z这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。* ]! S' U. ^3 ?* s9 }3 R0 u

6 `1 o: ^& \8 x- \以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

346

主题

559

回帖

3656

积分

管理员

积分
3656
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?
6 L3 A+ W1 J  W1 i7 l
* r; d8 a" K; \+ \如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。+ f4 d1 j$ O/ N& I* H

% `) o% b6 i. w- }7 H' M& A以下是创建自定义插件的步骤:
  R0 r) s6 e. U; {5 s. {& |# a2 ?% h7 d
1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:8 ^0 Y* {, E1 l# q4 Z% [
% \7 E; T+ L) v/ e2 V% O$ Y
   ```
0 S) u" h& h! o; q1 u6 K, h( f   <?php! X2 l6 x# n5 @- Q) c6 U7 p. m
   /*0 D% F  Y* R* C
   Plugin Name: Site Wide Notices Plugin
" T+ O0 C( r; L, i) \6 s  R7 S   Description: Adds a new custom post type for site-wide notices.
( h5 ?, E: C9 ~9 m2 Y   Version: 1.0
1 C. ?+ Y  D+ e6 S0 Y+ s) p( y4 V   Author: Your Name
0 Y: n5 W0 u" i+ I& i& Z+ L0 w   Author URI: http://example.com
# C1 {+ s% V$ L) P5 G( n5 f   */) X9 k$ h1 u' {7 P. Y

3 w3 l- w; |0 R2 ]* H7 L: L0 i   // Add plugin code here...
  @0 e* l# ~  `7 X- s) x+ m/ M% s   ```
: O' ?3 H; U0 v$ S: f" G" U; _' p3 D& E; z
   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。( f( _2 {0 p* t

# x: A. y, X7 Q4 \2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:
; C0 h2 P7 S4 H8 s4 L0 ]1 N( X3 j! y" a/ i! a$ Z! {2 A; g2 C+ h
   ```
# L* q5 O3 I/ P6 w   add_action('init', 'create_custom_post_type');2 P+ z( Z. q) ]+ I# X7 H3 l5 ^, m/ e5 T
   function create_custom_post_type() {
, ^: y0 V& x6 n      $labels = array(
$ p' ]! p7 w, k) E: i) _          'name' => 'Site Wide Notices',4 K! x* D! c2 g1 Z3 Y6 v
          'singular_name' => 'Site Wide Notice',& B: {) @! O* `6 F6 F
          'add_new' => 'Add New',
4 ]' W  S" o' C, r+ R          'add_new_item' => 'Add New Site Wide Notice',
: b/ I( ?$ T4 R8 }          'edit_item' => 'Edit Site Wide Notice',  P$ n  F+ N7 f* i% @. _; ?! |
          'new_item' => 'New Site Wide Notice',+ z. y' |  r/ B) B
          'view_item' => 'View Site Wide Notice',9 B* d! n6 a9 J6 S3 `' S
          'search_items' => 'Search Site Wide Notices',
/ s- `5 J: ^& j9 z$ q          'not_found' => 'No site-wide notices found',
7 c+ Q8 K4 q  _2 ]5 [+ [$ v2 g+ q) D          'not_found_in_trash' => 'No site-wide notices found in trash'
+ V1 K( w& j% W4 F) L3 e      );: }' m" a$ X" y
, U' r# K! S  X6 n% E$ k
      $args = array(
6 h8 g: B+ Q8 G0 ~8 X; C          'labels' => $labels,
0 }$ y+ p3 J/ L# p; Y. j          'public' => true,
9 @, R$ [; T5 I. p9 }          'has_archive' => true,5 \- j6 F5 Z4 y6 b
          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),4 T& z" ?& u% ~" J" k! Z
          'taxonomies' => array('category', 'post_tag'),
) @. G3 i) U! p) ^& |3 S; Z          'menu_icon' => 'dashicons-megaphone',
" c. _( F; W; ^* {4 C. r) T          'menu_position' => 5,
5 h' m1 L6 E1 c5 [5 D, J) b, ^* o          'rewrite' => array('slug' => 'site-wide-notices')
* Z  ~( Y. g, L4 }+ U      );( [  ?% Z+ Q2 p6 r  t6 B5 g

# f2 V) N% p- x1 |7 [; @      register_post_type('site-wide-notices', $args);' r6 Y/ Q. [+ V3 \, D8 V
   }* A9 l# @, o+ z0 j& P
   ```
  s. \2 v2 Y  d8 W) `) [1 k' F5 B8 `1 ~' T
   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。) x# ]+ w5 I8 ]0 l

) g" d' c! r4 I2 o0 @3 R4 Q- ^3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:* L( a  Z+ O. f7 ?# n
- e5 e; i. B# J+ o7 T: i
   ```
% S& ^6 @+ R3 j) S" v" v   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');
0 D: `$ e+ h+ I3 B9 A) e- m   function add_site_wide_notices_boxes() {
. Z; u  S4 w# ], V' i5 Q      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');, p# H% t. i  v0 D" b
   }0 W$ p( k. v& O# X% E- N

$ g/ Y0 ~/ N: w5 B0 K: O8 H   function notice_details_meta_box($post) {/ a4 n0 I) L8 i( T8 e9 m) i
      wp_nonce_field(basename(__FILE__), 'notices_nonce');) ?' ^  l0 n/ E: r
      $notice_title = get_post_meta($post->ID, 'notice_title', true);1 b- a1 W) n# W7 K; @/ K
      $notice_content = get_post_meta($post->ID, 'notice_content', true);5 ]2 l. p) |% |
      ?>
5 Q6 b: g( b' m3 \      <p># ~7 K2 O8 S% J/ k( V
          <label for="notice-title">Notice Title</label><br>2 Q( S3 z, m2 P& V: h8 O+ f
          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">) x5 U7 U8 o: [) K" G
      </p>
2 P1 v2 \' @  U7 I3 A! L8 a( C6 c      <p>- \4 j  c5 l: A7 R. d
          <label for="notice-content">Notice Content</label><br>1 D# b9 b  j. }. G- u! Y" O
          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?># h# r" g  x' G' t! i
      </p>- O9 K' d3 X- @% ^; U0 N! m4 C6 q
      <?php
# Y# Q; N& a: W! S% H   }
, ~) P- D9 z- l  j& }/ `7 p/ O8 c9 O: q
   add_action('save_post', 'save_site_wide_notice_meta_box');
& F+ z% G+ `8 @$ D% |' k   function save_site_wide_notice_meta_box($post_id) {* h/ H4 c! s; S  U
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))
) d# L1 s' B5 b+ N0 b" M         return;
- m/ N( J* P7 b1 ?! Y, r      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)
& ?8 N; A7 G& w         return;
" n; n" Y2 Y$ t; I: y( z- ?' w( f% r8 ~$ }% z' q6 t' [: W* X
      if (isset($_POST['notice_title'])) {
0 O& ~" z* E5 K% c6 X1 }$ ]          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));4 g6 S; j9 D; B$ F& |
      }
' |( j* R& D4 Y  C3 H      if (isset($_POST['notice_content'])) {
; p6 J, E- l+ E$ P+ j; F: F          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));
) s2 l5 ?( f5 L4 f. G% S5 {      }, i8 [3 Y3 Y. `0 l! d
   }
' M+ U+ ]9 l0 r   ```
7 T" k" J+ Z5 C0 e
' J0 u  a' i- m  [& a7 G+ T1 C   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。6 x! V$ F, Q* ~( Z7 a8 q

7 l# p! ^. k5 f8 W: v8 H4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:1 o: @$ H+ x( A4 _) n1 s0 B- o

* H  K0 k4 }; V. p% e* M2 c; D   ```
7 a( h. ?4 K7 P* @6 a3 ~   $args = array(4 U4 z6 @% E" e# c. W8 R* r
      'post_type' => 'site-wide-notices',8 ^  Q# W2 u/ {+ \( p! v2 v0 }8 ~7 |
      'posts_per_page' => 3,
! R" W$ Y: r, e, s      'order' => 'DESC',
$ f& T2 l2 ?; W+ L6 v      'orderby' => 'date': Y9 W0 d6 q- Q5 r) |# a
   );1 I" P6 m1 ^: X9 i" s
   $query = new WP_Query($args);
" `+ C) p  D  L' `- [2 c3 l5 @   if ($query->have_posts()) :& V' c1 g- f  c1 S3 y. A9 A
      while ($query->have_posts()) : $query->the_post(); ?>$ z; O, c: q% N' X% Y* d5 s" a& }
          <div class="notice">
7 N4 y8 z- L( l              <h3><?php the_title(); ?></h3>
2 N' t) k7 b" t8 w" ?              <div class="notice-content"><?php the_content(); ?></div>
- R$ i) G8 c& r4 @$ }          </div>
+ ^7 z; t& `' X  ~* e; s3 T$ S$ b      <?php endwhile;1 a0 F2 i; Z% }# U' V8 Q4 y! G, _( \
      wp_reset_postdata();
! Z' W3 M- q4 }, l& X5 K2 W   endif;3 f5 j( z) s4 C( x- J0 N* s
   ```7 i" X) a: k2 m
! R+ o- ^- {. Z& f
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-4 05:31 , Processed in 0.013956 second(s), 2 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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