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

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

[复制链接]

340

主题

529

回帖

3532

积分

管理员

积分
3532
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:: J) @# m1 ?; @+ c: q7 j! L
/ U6 g1 L! F* l6 v9 A
1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。
0 ?6 d! b0 B6 j$ U, U0 b; B+ p. ?3 D% O& b& L5 F2 `
2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。
% Z- f- E: j+ w% y1 B# S& U- m
, A! G6 _4 T" D, b' D3 [) [3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。
4 U/ J& U: L: M& S, g, C7 n$ J! S3 u& R, c2 g5 ?# P  j
4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。% T7 W/ h! s! K
- x5 s9 W9 d$ s8 X9 x' C" ?8 R  F8 S
注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

340

主题

529

回帖

3532

积分

管理员

积分
3532
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?
& b2 K0 N- d  D3 U9 {; o& ~2 B) M. s" e; C. v9 R6 u! R; x" y
如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
; x7 _0 f9 T4 s) k
7 E  a; b: `5 A) v1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:' E! B; r' D) }+ I

# G7 K3 X  s: Y3 C  ~3 E   ```
+ u/ m- U1 s% [/ F- A   add_menu_page(
( I$ j; W% g- v9 j       '全站公告',! O3 d6 P9 A, e  e, o. T  Z* d! T* Y
       '全站公告',  U- ?  G& ]: r; d5 B5 C7 b
       'manage_options', //需要的用户权限
& [) B1 M+ R. V       'site-wide-notice', //后台页面的 slug
9 ?( t2 Y. \% y! y       'render_site_wide_notice_page', //用于渲染后台页面内容的函数
% f) W; G# R3 f" j5 C, \# a3 I       'dashicons-megaphone', //用于显示在菜单中的图标
0 f. w2 U$ n- |9 N  f# @       30 //菜单项的位置
$ v, X% `2 P$ r( |; e8 N' [. h7 I   );" w2 ^4 {, z* U0 _5 D4 q
   ```. {( w/ N/ ^3 \" [/ v, x

1 H  O9 M7 O6 j: P% \   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。
1 L2 H) G( r, C; ^8 o! M
6 ]" U! D7 E% [/ j8 @2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:
3 k: R. j& W5 E1 O7 Z# J& u& x6 m" z9 o+ C
   ```
1 a1 o, y( w( T   function render_site_wide_notice_page() {" n5 ~  @/ V$ q- R0 _
      // 渲染后台页面内容
0 X: Q9 j  b/ a+ |; G! f      echo '<div class="wrap">
* p% r& E; K0 ~+ Y& }          <h2>全站公告</h2>( x  |  n' N3 f% ?. ~' @
          <form method="post" action="">
& A4 l) M' k! S% ?- q* G              <label for="title">公告标题:</label>
$ H) j& d3 o5 E/ J8 S% c2 z              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>- k7 v# |  K$ @$ @! z' f' L& K0 P
              <label for="content">公告内容:</label>
( i8 |8 i4 N7 c3 G/ q0 U# f              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>1 F1 K9 U0 }8 F% L0 J/ D) z# C7 y
              <input type="submit" name="submit" value="保存设置">
' m  n/ q5 [- }: g          </form>. }) q9 C! m  d! n( r, i4 }
      </div>';3 O) X) o6 I' r3 @" D
, U. s2 p1 b4 x  L5 H
      // 处理表单数据! U! e9 U6 [* J9 w6 }
      if (isset($_POST['submit'])) {
+ H, [7 N) t( \3 m4 H) ~+ Q          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));
6 P0 K! k, R# d3 |9 R$ r. O  K          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));
+ g( V) O/ E# B/ X" S  Z1 L1 e" ]      }. O1 S- I9 d4 I9 h
   }
* `" m0 ~9 V: O% [3 G9 ?2 [9 {) i   ```
6 N) l- j3 P. e' G/ b2 \% K/ b! j( S, |4 [3 v# B
   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。
$ u; T1 G0 M# B: ^$ B% H9 L# l$ ]0 Q; n& y
3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:8 ?# \5 I. e$ O+ ]
1 L' j) F2 B" S# Q$ M' y
   ```
# N* p* @. D4 ~$ O  `, |1 b7 |0 O4 [   <?php9 J9 A5 K2 K0 @
   $site_wide_notice_title = get_option('site_wide_notice_title');) g5 [: `  k& i- O
   $site_wide_notice_content = get_option('site_wide_notice_content');
$ s, @6 g4 n8 t7 l4 ^   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {
& ]  l, Z. t7 X       echo '<div class="site-wide-notice">';
3 k/ o1 Q6 S0 ^, U" }  H; }: o       if (!empty($site_wide_notice_title)) {
* L( o# x6 \4 P3 |4 q1 |* Q           echo '<h3>'.$site_wide_notice_title.'</h3>';
: ~5 C0 H7 C2 t; m# b- X4 T6 N       }
) Z  ^1 N0 @& }* P- y8 Y( J       if (!empty($site_wide_notice_content)) {
1 S& ]1 x) T* p8 A' b4 B           echo '<p>'.$site_wide_notice_content.'</p>';
$ l3 H# q% y3 I       }
" E7 }' E( Y8 j) ?; e" o       echo '</div>';8 X) T. Q2 i: \! \+ t" i! [
   }
4 L2 ?) P8 {3 q   ?>% ?7 X3 `, {& j% S/ O, Y
   ```2 _/ q+ B/ Y& }# u% z6 S7 e
/ O4 X% N3 r; `" N" f
   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。
/ w0 b( Y5 ~% o5 ^; O2 J) T- m& @) b3 Y2 {* C5 y1 I
请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

340

主题

529

回帖

3532

积分

管理员

积分
3532
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?
2 I- m# c  s: w: I# q& `2 q. A# i) }( @6 ]# T+ H& I/ G' z: {, ?
您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:
# C- `1 o% {$ d2 d5 R+ F+ e( ~0 Y/ B0 F( O/ s# b
1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:
1 }, \+ l3 o8 j2 J1 k. W3 Z" Y
; [; i  F" P# S6 j' f: H. M$ q/ ]```/ K! y, ]; f6 Z7 \* E
function create_custom_post_type() {$ r0 u  U& m. H& e7 e' G* D% J
    $args = array(5 }- y4 L3 \0 a4 \9 }
        'labels' => array(
# A( J3 V' u2 q: z            'name' => '公告',
* L3 d! o8 r7 P# [' e) o& R            'singular_name' => '公告'/ @: S9 U6 s9 L; V$ Z) |3 i
        ),
$ _% N; s0 k, k: j- s: m; D        'public' => true,
1 S) |# I! o& K0 O        'has_archive' => true,9 W% l, L: u4 |
        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),2 f3 e& I- K! R  Q- |3 s1 f. C) U& H
        'taxonomies' => array('category', 'post_tag'),
! a- L3 d$ }1 a% Q2 v5 G4 E% N  }        'menu_icon' => 'dashicons-megaphone',, E( s2 c* [" p9 r- R
        'menu_position' => 5," x* J- k  d/ g3 G' i( p& Q+ M
        'rewrite' => array('slug' => 'site-wide-notices')
" x5 H- W5 I) T" |    );' Y1 l4 a9 v2 i9 O0 s
    register_post_type('site-wide-notices', $args);. e! I1 Z+ {+ k5 U2 j: U( m
}2 k1 e( ]' a# e' d2 a" U1 Z1 t. l
add_action('init', 'create_custom_post_type');2 P9 \4 Z( W2 X/ `" C' M
```% n, D& h7 ^) q

! P" o) E+ y, t  |8 q在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。" C$ V5 Q$ L! M

* w$ A/ ~. Z- e" O9 |9 Q) w4 T2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。
" c* A3 E4 R" T% f
" ~$ ^( i  d' V3 U0 h3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:( X$ Y9 {$ w3 q
7 Z5 Z: V( F- ~  p& [
```9 L; ^. w! L1 i0 r+ c
$args = array(
, M# O4 ^0 b2 r3 u$ O- H    'posts_per_page' => 3, // 显示的公告数量
9 K- P  g  R2 L: [5 E. ]    'post_type' => 'site-wide-notices', // 公告文章类型1 M: D9 A* S5 f& m. d
    'post_status' => 'publish', // 公告状态
0 ^, Y; T% q1 \    'order' => 'DESC' // 排序方式* U" W/ ^5 ?0 `* {
);
  @7 W4 K! r* z; j
% i; c9 d! S. ~9 Y$notices = new WP_Query($args);
5 ~3 i% M1 l5 O6 Q3 cif ($notices->have_posts()) :
! b3 F* |1 A- T    while ($notices->have_posts()) : $notices->the_post(); ?>8 R1 _% ~/ [1 @# v* \3 R
        <div class="notice">
. g; ?) {  K$ W1 N            <h3><?php the_title(); ?></h3>2 M4 `8 i. u- G7 I/ h' d
            <div class="notice-content"><?php the_content(); ?></div>" Z; X4 I# h9 r6 g8 n- G/ W  d
        </div>
( N: X; _3 W( y, N/ O  u7 U) C- ~    <?php endwhile;  |7 C; x  q; _) {+ `3 M# j
else :5 I$ N4 J  C/ I
    echo "暂无公告";1 U! i! Z0 S2 o' d3 J4 E! ~
endif;4 J; _1 {: K2 g9 P( x% i% f! U
wp_reset_query();
7 j  B$ Y9 I5 \& E2 |8 d```2 k3 z: c' T$ P* S3 U, X, A- i# @% S: }
  J8 c! `! d  r# S3 ]8 m7 p, d! k5 y
这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。$ t& _; t4 ?! t& ^( w
: }9 J, o" S: d! P) @: [0 I
以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

340

主题

529

回帖

3532

积分

管理员

积分
3532
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?: Q- X. m; ?! Q/ v2 M

4 I7 y: C, G% \2 `如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。
, m: |4 `( K* _
5 ]# O' N$ g5 T以下是创建自定义插件的步骤:
; ?# O% z/ e  c0 X) v  i, S- ?, b; g
1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:( W! P  ~6 B- X! l7 F7 {

6 {2 e/ p- {! j, z, g3 V   ```
% i/ l. N2 E& k   <?php. c+ C1 X; a3 S8 M* H# m  _) o/ g
   /*
8 Z! o2 q* O  l   Plugin Name: Site Wide Notices Plugin3 @2 K, U( q/ \! d7 O% J! v
   Description: Adds a new custom post type for site-wide notices.
" B. J# U3 E; {& E! r; I% ?* T' L' ?   Version: 1.0
. ~# m. i3 v9 p   Author: Your Name; `4 S# ^3 E+ m% ~) M$ z+ [  [
   Author URI: http://example.com
: J: K+ o: ?1 u6 l' j& E4 p1 I% U   */5 _* K! ^4 f/ v. ^; t4 Q5 T2 O' ~

  V0 [" x' i8 P   // Add plugin code here...& V4 u6 S* r: Z  ^8 s& M) A3 a
   ```! ?7 t! V2 m4 [

  s  E$ ^3 h$ Z9 N  I0 ^   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。% p' z% B- I/ a7 b3 G. L

" _  h  I+ _; i! J/ d8 ]5 ~' A) E2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:. m3 d1 C: f' z1 {( N
" d1 g) P5 z1 }( r2 A9 \* X
   ```, [  w& G& ]' F& u
   add_action('init', 'create_custom_post_type');9 V3 U; T* z3 h5 v4 U
   function create_custom_post_type() {! ^! b: z. c5 `0 o$ R
      $labels = array(* c% ]4 ]0 E8 u! E
          'name' => 'Site Wide Notices',9 z# o" O$ i6 z: Z2 x
          'singular_name' => 'Site Wide Notice',
. H2 |0 V" z' [7 ~, D* C          'add_new' => 'Add New',& b, Z3 M0 z, i; W. g
          'add_new_item' => 'Add New Site Wide Notice',: r2 ?( d2 R: x/ J3 o
          'edit_item' => 'Edit Site Wide Notice',
, C& D. v4 b& X2 Y3 q          'new_item' => 'New Site Wide Notice',
) J* S- u" I9 A$ ?3 |          'view_item' => 'View Site Wide Notice',+ T' w- r4 v/ O6 d; ]7 }$ O7 |
          'search_items' => 'Search Site Wide Notices',6 a7 b; ^5 b4 U$ X3 R
          'not_found' => 'No site-wide notices found',4 ?# t4 Z8 `1 `. s/ w2 L
          'not_found_in_trash' => 'No site-wide notices found in trash'
: L  i( D4 I" A/ o( O% P      );
1 Y4 Q0 f# d4 a
& n$ M4 C6 _9 n3 n      $args = array(
+ a7 S0 K% V8 Y% ]          'labels' => $labels,
4 b9 S& G6 W. }- Y, z# f          'public' => true,
9 t6 s5 q: s" f) b& x6 [  b. @          'has_archive' => true,
) T* S3 i2 W: [          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
( q+ z& I; o9 G          'taxonomies' => array('category', 'post_tag'),8 _" h0 X5 o0 d6 W
          'menu_icon' => 'dashicons-megaphone',% k8 W: x7 v% y  ~2 d0 k2 `2 s
          'menu_position' => 5,
5 o" E; E$ R( M; b6 A$ B% n4 ~; s          'rewrite' => array('slug' => 'site-wide-notices')
$ f; d, a8 d% f      );5 J  I8 k( f* ~1 [, e
6 L6 k, K5 N/ y* e
      register_post_type('site-wide-notices', $args);. z; N3 {3 p9 Y" c" @/ k
   }
: u: b+ F. s/ R0 N' [   ```9 d, Q: V1 J9 L0 Z: X, \7 u& k7 R

5 n: a; G& z8 h9 D: Q7 @0 L& L% @   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。
/ [4 Y0 }, e" S
4 ^2 W9 W+ _* i% ]2 D- E3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:
& n0 Q8 p2 L8 c/ i7 D: H( K! [! @7 M  H% ?6 _1 P
   ```+ S; h7 V$ ?3 Q
   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');
: W- v0 ]; T8 d" q5 G   function add_site_wide_notices_boxes() {9 d7 o5 t5 I! z& P: H/ m$ x
      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');
& S8 T9 n$ M# c& o* r$ c   }  \# a: B( [; b& w7 q

' t- j3 P5 y# D1 W: s9 V" o7 m6 ]   function notice_details_meta_box($post) {
. l# i+ Y' F# K1 y" n0 w      wp_nonce_field(basename(__FILE__), 'notices_nonce');; y$ R8 c/ i7 T, b
      $notice_title = get_post_meta($post->ID, 'notice_title', true);
  [1 x6 w' J( [" y+ n7 S' s. T% O) b0 J      $notice_content = get_post_meta($post->ID, 'notice_content', true);% L) I6 t' V+ G
      ?>& D) `! f7 n% Q8 Z
      <p>) {8 c1 o7 ]! \8 [: I: j% ?
          <label for="notice-title">Notice Title</label><br>  }) v' Y2 L" M* j: x
          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">$ M, [' a( X4 g8 y1 l- N+ u5 X: H. q
      </p>& {) N4 N# c* Z6 _
      <p>- b. B, `8 v, v3 P7 o/ a2 E1 m1 S! b
          <label for="notice-content">Notice Content</label><br>4 d' G- p6 Q: }) g/ Q& o
          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>' {5 f* H, ?  S8 v
      </p>
% g$ w9 C+ X# s+ R% K      <?php4 o! L% r6 N$ Y. p& f
   }
. Q" y; ~. J7 t1 m0 ?( ]4 J. s
  s9 Y1 d. q; B( U2 T   add_action('save_post', 'save_site_wide_notice_meta_box');9 I5 X& g  \, c6 G' }
   function save_site_wide_notice_meta_box($post_id) {* m1 m% k2 R) [6 M' N9 N! h
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))' G- [$ H0 V3 Z2 i9 t
         return;, h) H. ]+ G& ~) }' N  ]0 F
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)2 l7 Z: @4 r0 I# g" J" ?, [
         return;0 v4 Z9 _  ~8 Y8 _, R2 J! n
3 z& ~8 k; b  K3 t
      if (isset($_POST['notice_title'])) {
# `. K5 Y+ N8 g* ]! w" i9 L          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));; m8 J' B' T# ^4 R0 e0 ?" T
      }8 w& @& ~' T7 x+ H1 o8 u. }, K8 [
      if (isset($_POST['notice_content'])) {
  a4 y! ^- z* ]3 l          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));
. b; n5 I  L2 O) E% Z# ?      }# W. r* j4 i0 Q' ?/ P0 \
   }* z) u: Q* H& [- _8 `. J# f
   ```3 u2 F) u$ d4 R- B

; g2 d9 O2 W7 s( H6 ^   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。( d: H* t7 W6 G6 j' R! r1 o; ^

: y! e7 k# Z7 x3 V3 n& a4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:
" f( F4 w8 d) s+ T# k; v
4 d3 C' Z! t2 f/ j" e; i   ```
& L4 l5 t0 @1 f0 @9 m0 S, p   $args = array(
1 P$ G1 ^% |) W- @1 P  k! q      'post_type' => 'site-wide-notices',
* l/ m/ E# ?/ v- W% b      'posts_per_page' => 3,' b, H, ~6 h' k
      'order' => 'DESC',
2 ]+ b9 e; [# F  m( u      'orderby' => 'date'
/ i. B. |1 e3 v& G0 h; M   );7 x( ]" C! L% [' H
   $query = new WP_Query($args);+ A- p& g: p; x7 {( F" A
   if ($query->have_posts()) :# Z' q  s. `5 `: a) Y4 b2 a8 l
      while ($query->have_posts()) : $query->the_post(); ?>1 S9 ~  C% I" U" E" S5 {
          <div class="notice">* }1 M# o0 g' n
              <h3><?php the_title(); ?></h3>2 d# [3 \7 R$ R) G
              <div class="notice-content"><?php the_content(); ?></div># x. g$ A' [$ N% s" J# g$ t
          </div>
' Z' ?6 g+ p  \) E      <?php endwhile;3 _% h2 l% T* p, t* ^  @1 v6 R
      wp_reset_postdata();+ ~. X* C0 w! O! {
   endif;+ j3 ~2 a" [+ {% a
   ```
2 _! i; v1 a$ j- J# j( M" t
( t' _: J9 \0 O9 @) C   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-21 06:16 , Processed in 0.024265 second(s), 3 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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