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

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

[复制链接]

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:: R  m7 z; Y- e6 P, v% Y2 F" a

( W( y0 H% L/ \% r1 K6 c0 W  Z: P# ~1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。. e" p! I* x0 P
* T0 t) P7 e5 B* r8 @! K6 ?
2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。4 U1 i" E# g3 E5 [& D! i
; Y! F  M' [% f6 g; p9 U0 w# h* |1 c
3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。0 f$ C) \9 z2 j7 ~
5 y4 |# w1 R4 P! q! j
4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。
8 Z/ H) ?4 N8 s9 i6 ~
3 }  U. J1 ^7 R- X+ F. z0 {& D注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?
- ]" |8 P# D! E$ U6 J9 G1 ~( p5 D6 @* S/ v$ E
如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
/ u( i( D5 N9 Y4 Z9 v$ a* c4 J3 C0 ?$ H9 y
1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:- l' y" m! [! j6 P' l- q- m

, S! H1 i3 a9 A& Y. n( N  G' J   ```2 u# S( K7 n5 J
   add_menu_page(* ?# J' I, q9 ]! h
       '全站公告',
3 ~" `9 U8 \$ z, N6 N# C7 Z       '全站公告',/ P+ e- w, c9 i# m9 [
       'manage_options', //需要的用户权限
0 g% Z& S' y  E- `6 ~% M1 ]6 }       'site-wide-notice', //后台页面的 slug# y' b) o/ X( i' ^3 u; j& q$ t
       'render_site_wide_notice_page', //用于渲染后台页面内容的函数( M8 t/ ?( q# {6 M/ o
       'dashicons-megaphone', //用于显示在菜单中的图标
1 V3 c& o+ @3 i* R5 O+ B; U& M9 P       30 //菜单项的位置
: U- T# S7 P1 c; M3 [/ K7 E0 u   );/ K% ]+ x& t8 C- \
   ```5 x  [/ g3 q+ \$ c3 d; l

7 K6 n% g$ S) H6 `5 Q   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。
/ P3 u" w0 G7 h$ G
! H$ {# E6 D% [; h2 V2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:
- _1 t$ E3 z  T8 U
. {: r9 O6 O$ q9 C) y2 D   ```
+ a* d7 E8 b/ J  M( ~# {1 |; ^   function render_site_wide_notice_page() {
: ~+ |4 d( F3 y$ C) C9 t0 r& H      // 渲染后台页面内容
, r* g9 k% A1 }8 ]6 X6 A5 T, {      echo '<div class="wrap">4 n% i7 q4 ]4 I
          <h2>全站公告</h2>4 }  J# r3 F* y4 d' t
          <form method="post" action="">4 y" {# ~# x+ J& d- e7 T1 l
              <label for="title">公告标题:</label>
1 v; p* ^  k- |/ Z" D2 g              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>
. M" W8 J0 c. q/ a# R              <label for="content">公告内容:</label>9 T# v$ c" w9 V( b9 \' O
              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>: z# F, `( S/ C) K( u; @
              <input type="submit" name="submit" value="保存设置">
. Q4 r* f$ }6 [. r& |# r          </form>$ ^& N1 ?& o9 O
      </div>';
! ^' l" h7 d2 G; s1 N( S' I6 x( Y
. P7 c7 q( g, d# s. ]4 q      // 处理表单数据
# c; l, J$ ^" r% M3 a: y0 t      if (isset($_POST['submit'])) {. ]  s. J) }; m0 e
          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));0 R: m5 h7 \+ ^, k$ J. A
          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));% o- A: O9 x# P  `
      }1 Y- z" h# S4 [& G# O& {* @5 N
   }; q; o8 g  V$ ]4 `5 r4 Q+ T; D! J: }
   ```
' x$ p6 a( |# `. t+ X3 n1 v& Z1 Z6 s1 q8 B% ~
   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。
0 i' O2 `* h4 l2 F
9 E, j9 e3 ]2 ?0 |$ B; p3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:
! w: u8 D/ m! d- j+ a! N8 B9 }: H
   ```
; C$ A) v4 E5 l  P3 _: \   <?php
( @6 s8 D( p7 G/ D( U, Q; _   $site_wide_notice_title = get_option('site_wide_notice_title');
4 r6 G  j3 }& [   $site_wide_notice_content = get_option('site_wide_notice_content');7 X- q! }9 n1 X8 y( x4 m$ v
   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {
/ t7 y# I" b6 Q2 s9 F8 @9 _       echo '<div class="site-wide-notice">';0 y; u! \/ J+ c. l
       if (!empty($site_wide_notice_title)) {+ n7 _4 F: _: o
           echo '<h3>'.$site_wide_notice_title.'</h3>';
* t: K' H  ]2 T, L, S8 z1 F/ M& ]8 [       }
+ S3 A' n" d# f6 A/ z9 |# e       if (!empty($site_wide_notice_content)) {! i6 F) n: @( o& L8 u) b5 _
           echo '<p>'.$site_wide_notice_content.'</p>';
8 A$ G, l& K$ \       }
( T& Z: l; m, b2 D" u0 ?! D/ }6 {$ n1 e       echo '</div>';6 O9 i9 }+ H* y! r( h2 E
   }
, B& t" L1 ^: o9 J! B3 W   ?>
2 P* A( [1 z* b   ```* G& M  y& K# c/ H5 a: |

) Z3 E+ m- C; F' D6 A% o   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。6 L% v  ^$ j* f: ^6 h8 z9 [0 d

6 T2 B* r% e  |( Y; w  ^请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?
7 H' ^2 ?; `1 h# {8 D& x- _* W  z6 Z3 `
您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:) g7 K" R5 ?, H1 h9 t

. x$ c8 D8 h9 W1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:7 `2 R: p  `9 K- Y

! o7 n$ e+ q8 {! S```3 H8 a+ I- |$ k6 k* e* M
function create_custom_post_type() {
6 _* J6 p3 ]! W( b    $args = array(9 o3 {! T5 {4 A% o3 @* z
        'labels' => array(
5 ]4 _6 x% Y3 Q  z; N& r# p( Q; X            'name' => '公告',
0 V" d; q8 X; F) M7 Q            'singular_name' => '公告'
5 A9 }- ]: |$ C; p        ),
7 ]7 S; B0 M  d; x8 l        'public' => true,
( x# }9 @+ O2 j4 Q1 b1 ]+ A9 o        'has_archive' => true,3 r0 B1 }$ B- E) l
        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
( K4 n, R" d8 S+ L. j: e8 M; v        'taxonomies' => array('category', 'post_tag'),
" s$ K! x% P0 Z9 r& j( o        'menu_icon' => 'dashicons-megaphone',
8 @3 ]7 |, M0 l# }6 Q# V% m% y        'menu_position' => 5,# }4 W* L0 b7 B# i- k+ A' @' G
        'rewrite' => array('slug' => 'site-wide-notices')
' `+ u, ]$ ~5 p: a; r    );
' C/ [1 W/ d! F# o6 }" I. i; w1 y    register_post_type('site-wide-notices', $args);3 ?( j' R" n  H
}
+ r6 T  S$ E3 I) nadd_action('init', 'create_custom_post_type');) Q: d5 _% [8 {/ w0 W
```
  K* K3 T3 A$ T3 K8 C" h
) W% K2 t4 k9 N: \在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。
5 o( p8 d9 b( d5 `/ P9 x0 S* d* ~7 y+ }# c: L2 d7 F8 k
2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。4 a' B3 }- [$ G: f

% j4 Z3 Y( U0 }3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:
/ c* ~2 O, ]! s$ q7 Z: @
8 H; m0 J8 V) [& n0 b9 d```
4 d# [# l3 s* q/ ?, ^" S3 T$ z% O$args = array(
$ Y1 b$ S/ w* x1 s    'posts_per_page' => 3, // 显示的公告数量
  ^$ F! `7 u7 h5 j& q    'post_type' => 'site-wide-notices', // 公告文章类型
9 j. E& C4 f3 L% d+ ~; K$ D    'post_status' => 'publish', // 公告状态
. e/ X; U) m* z8 m6 K    'order' => 'DESC' // 排序方式* Z/ p  w! ^" [" e% ?: }
);" G  Z9 h: q) v; M

. i2 T( N% f5 Z- ?  W/ w$notices = new WP_Query($args);
; c* `& z2 o/ D5 r, tif ($notices->have_posts()) :
4 q: O' s" P+ q% f& o6 n' d    while ($notices->have_posts()) : $notices->the_post(); ?>
$ f- ~( u! c/ Y! w0 @        <div class="notice">/ e3 S2 E6 K1 }( R
            <h3><?php the_title(); ?></h3>
4 i. c: K: L7 E6 h7 s            <div class="notice-content"><?php the_content(); ?></div>; S. E0 g( K; |% R5 l/ U
        </div>; Y; Q4 T2 N& e# n! T4 S1 L6 L
    <?php endwhile;2 x$ _: M: \6 I9 @* _
else :
# u- P- j# C9 k$ `$ C. {    echo "暂无公告";
. g- Y& [5 _3 Y, d* |+ H( ~endif;2 i' {9 h7 q+ K4 ?
wp_reset_query();) {# G. E& I$ z6 F4 H" n) U
```2 C/ q" ^% C9 Q* _7 S
1 }  @3 H( g+ y' j" D$ u6 ~  v
这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。
! W8 I1 x' i5 ?# ?& @  L& z+ L/ R' e4 E  O( p% [; x
以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?* t3 z7 h" o( x, y, J) X! v

4 @  D+ j. n% S+ X: B+ v( N) g: u如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。
) D9 `( {6 G- e$ I4 z
8 ~7 g+ `/ \2 E以下是创建自定义插件的步骤:
6 I9 V$ A+ B6 L/ ~
" y! z' x# S1 @: Q% a7 u1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:0 ]9 l, u$ h5 Q5 l1 X. w

7 k  N! B+ c' m   ```
* W9 d$ i/ c6 n% K1 u   <?php
8 U0 x0 k8 T4 d   /*5 S, Q$ z6 E8 }  k/ r
   Plugin Name: Site Wide Notices Plugin
. @* M# F. q9 C) U% u$ a5 Q   Description: Adds a new custom post type for site-wide notices.
3 b* Y' z. t1 ^; R1 x   Version: 1.0
5 F2 C4 t  S; \   Author: Your Name- @8 q; Z% J* b
   Author URI: http://example.com
- g1 h3 v% K9 s7 l# ~9 g9 x: b0 {   */* J0 A, x" v$ Q4 P3 j9 k/ b
% J$ o* g/ F5 q3 ]
   // Add plugin code here...
) P8 p( W/ @* H2 u+ ]7 C6 X4 f   ```5 Q" [' `5 \& ?$ J

  Z* d2 ~7 }/ W  i: d% L   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。
$ u; E/ [9 h8 S; f2 Q$ f3 X+ n4 O2 g0 m/ E+ i% {# ?5 ~$ h% w# U
2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:+ p8 H# Z. u) o1 T

# R) B, g) h7 S. F* V5 M   ```
  G; R# @! g9 p. }" p$ z   add_action('init', 'create_custom_post_type');
8 X% ?0 z4 f: Y: j8 `   function create_custom_post_type() {
1 P. d& h; y! q  _% B      $labels = array(
. V1 W. l5 O- p! Q+ H          'name' => 'Site Wide Notices',
8 J# V+ j* C, d! N          'singular_name' => 'Site Wide Notice',
8 H# ]. s4 _) e" t9 o          'add_new' => 'Add New',
1 U) {/ |, S  X" X, o6 F+ I          'add_new_item' => 'Add New Site Wide Notice',, \7 ?1 J7 D. E9 j% g' Z% p. \
          'edit_item' => 'Edit Site Wide Notice',
& q$ N& v  ~, P" Y: q          'new_item' => 'New Site Wide Notice',
. t7 |% x4 B; o( r# }. F) d( C          'view_item' => 'View Site Wide Notice',$ n) e/ c0 c8 Y
          'search_items' => 'Search Site Wide Notices',# t/ z0 b/ h7 Q+ S
          'not_found' => 'No site-wide notices found',
6 y( M7 \. c1 v1 V          'not_found_in_trash' => 'No site-wide notices found in trash'
. P6 o3 J9 i7 F! e      );
+ _9 F" m# n% _0 e2 i' ?% s, H! g3 u' y$ ~& o5 Z
      $args = array(0 L/ b  H. }# }- `2 b( l2 M! r
          'labels' => $labels,8 }6 n; `% T, X; M- o; ]
          'public' => true,
. \& E3 L' `# J( {9 |6 s- ^          'has_archive' => true,
3 P6 s4 C0 J9 v- j          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),5 m1 p/ q# ^* H: ^, F2 o# j) l' @) r
          'taxonomies' => array('category', 'post_tag'),
8 h( O1 Y$ h  R9 F8 `+ {  Q( n          'menu_icon' => 'dashicons-megaphone',
5 t  T% \8 t1 u% s8 P          'menu_position' => 5,+ i% ^& i" U6 }# S% ~
          'rewrite' => array('slug' => 'site-wide-notices')
( b* b1 r/ K! J9 f( {      );
) {( O  U. K8 l! U  h0 Q7 u; E
  L  s$ M" {5 M* ?+ m* }; Z- F! f5 }      register_post_type('site-wide-notices', $args);
* G8 h2 a& N6 `   }
4 N0 X" O$ A% V- A( ~. Q7 G- M1 b   ```
1 D5 D, i# _# U; G$ H' W+ b; P5 J) e+ A! L8 K/ z. I
   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。
+ q! H4 m: ]4 @8 z" ]5 Q- g3 \
* V4 v6 [# g9 ?3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:$ f& R: h& q" `' X5 A

! y4 c+ S. E% F$ m* ?) S% [   ```8 w- i5 p2 }% U
   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');
- k" \8 A* w; g- ?6 K   function add_site_wide_notices_boxes() {7 p5 F) q9 y9 V* ?" [7 E2 [
      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');
! h; m9 F' V/ W) D* U   }$ b) M, U9 r. w  b( [4 l" v. }
3 j: t, d; i- g
   function notice_details_meta_box($post) {# G7 G/ ^8 d! X/ P! ?# d! I+ i+ e; Y8 n
      wp_nonce_field(basename(__FILE__), 'notices_nonce');
$ N5 I4 t8 g: W      $notice_title = get_post_meta($post->ID, 'notice_title', true);
% [9 B1 u  C4 m1 k      $notice_content = get_post_meta($post->ID, 'notice_content', true);
+ j$ \% o: D: m3 i+ D: z' C  O& V9 l3 G      ?>
+ K' v6 x( u$ \* _4 b! y      <p>
/ k+ k6 ]- @& }" {6 y% X+ p9 q3 x          <label for="notice-title">Notice Title</label><br>1 A0 w, t5 W0 B8 W
          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">
+ V' S% S5 e$ Q; }% @( X' ?/ h      </p>
& B& e' U- E9 @- H. `3 h      <p>
* _2 F, r( r: X/ m          <label for="notice-content">Notice Content</label><br>
) ^" F. d/ W8 P2 B          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>% n7 X" t  K) `( @3 x
      </p>
* ]. E; S- v2 b3 P, l  G      <?php
/ Z' k; f) E( ~) ^   }1 b: H. E" {5 E2 z* L7 ~% J( ?* e" l* H
+ W! l9 }/ d9 b& G% ]; @5 k
   add_action('save_post', 'save_site_wide_notice_meta_box');
/ s2 x5 _" b5 w   function save_site_wide_notice_meta_box($post_id) {- }. K1 }: M$ k, b
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))
6 w+ G- v2 d3 q5 s7 a) I         return;0 a: V: r2 d$ g! n5 F% k. @
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)
/ B- `' H, A7 S         return;
3 @( H: F. U+ E- c. ]0 u. b
) Z7 \9 Z: X+ Y      if (isset($_POST['notice_title'])) {% F( ~/ C# f5 \: T1 r  x/ O
          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));
0 p4 H/ V' s# y      }
! O! f" i7 n3 G+ L6 {% `      if (isset($_POST['notice_content'])) {
. y# s' ?. R6 I" `          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));
: P: d; R% T# h; h* r0 n0 ?      }. g7 A" ~6 j) d3 z3 y
   }2 ~6 g; t# ^0 C% C8 c
   ```
; K8 d4 j& ]) l) X3 H& s3 e. I$ a+ d9 v* L. g" [7 K; D7 \( _$ p
   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。: V2 n2 E( K* X& M- K
( r& e' t# X, z3 l6 Y* \
4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:2 j1 {8 J, e+ B% m
$ |2 t; M8 f' z* u# D1 ~: M( A
   ```7 d& s* x5 y9 }6 ?, r
   $args = array(
9 f* F# e( K+ y0 m. a5 \3 c      'post_type' => 'site-wide-notices',
; _( ^, C7 E+ Q* U- a8 H: |; P      'posts_per_page' => 3,7 J$ |$ g  X; d0 I) T2 O4 `1 Z
      'order' => 'DESC',0 c5 n6 Y/ s# e5 \4 O) O/ Q- l
      'orderby' => 'date'
; {9 q% y1 x" P! e, s- _   );
& u0 s* m+ o! a8 N/ r   $query = new WP_Query($args);
! p7 k; }+ r' A  F9 S7 z2 d   if ($query->have_posts()) :) \/ Q. \% x$ k# `
      while ($query->have_posts()) : $query->the_post(); ?>4 M6 L6 s, h  B: C
          <div class="notice">
8 s  d/ x0 `1 m/ s# U              <h3><?php the_title(); ?></h3>4 n9 d( a6 U9 n4 l9 V+ c
              <div class="notice-content"><?php the_content(); ?></div>
3 Y) g" ]5 x" ~  K6 d. U          </div>
( ^, Q6 b; Q8 ]: y3 e7 Q' J- t      <?php endwhile;
& ]9 b+ C3 b& F3 h      wp_reset_postdata();5 A0 j, X! t8 E+ ^3 \. [) Z! {. z' M
   endif;
8 a& j) Z+ v: n4 n4 ^   ```
, B2 i% ~  C" c* d! y. v$ \3 B+ ~+ H) W2 u7 N( ?9 w7 w6 @7 R. s
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-22 07:28 , Processed in 0.015344 second(s), 3 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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