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

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

[复制链接]

335

主题

520

回帖

3419

积分

管理员

积分
3419
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:! G7 U& M# f9 c- p* [+ Y

9 d& v4 y6 W9 W2 J1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。
# w, t6 p' t2 B+ l0 v
2 S" ^8 P% I/ N5 P2 p; U6 u2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。2 H/ u, T) y: B; Z: u% C

3 K" Q" x% Q+ `& o/ W) ?! ~: @3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。& E) @; \2 s; s8 L4 @

) m" e$ t" }( a6 U7 a% X: l4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。
; u4 z. b* P4 l6 A' d$ K- E* D. x. U+ W
注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

335

主题

520

回帖

3419

积分

管理员

积分
3419
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?
+ A9 b2 s' j6 q, P0 }2 x" \- H# R4 z0 t
如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
  o% ^# d/ w- B$ n0 v
& f- T0 _9 W3 A0 e  w8 u1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:
( M3 ]* h9 y, ]+ F8 f& O' ~5 W$ }% o# g6 U9 {
   ```1 H' j7 O1 u% E4 Z
   add_menu_page(1 F" M% S) _' V. g8 z3 X& Z% M; }
       '全站公告',
5 @8 F! [, D9 M) g* b. d& L+ K: _       '全站公告',
: i2 S- g* L& j; Z1 {       'manage_options', //需要的用户权限% A+ w* w5 ?5 n& m3 f$ ^6 Z
       'site-wide-notice', //后台页面的 slug
5 C4 Y7 I% b! _) @$ n) E3 b3 \- \       'render_site_wide_notice_page', //用于渲染后台页面内容的函数6 i. a8 `  k9 L8 R" Q3 e
       'dashicons-megaphone', //用于显示在菜单中的图标
0 E, `0 `3 `. f, E! B) i$ n7 t       30 //菜单项的位置
; d5 ^8 ]' h6 z   );
. v! n4 ~8 R9 l' e1 N1 b   ```$ Y( ^. S6 ?6 N- x4 {
, ^! ^5 |8 a$ c# D  i
   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。
, A8 j' G' {! s5 ~' P& @9 Y) G/ c; j: _7 |2 M9 J2 N, _
2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:
) H; g/ b) T; `5 j  }; X9 d! p$ ]) r: d/ n- }' P
   ```$ o8 ~) N2 o0 X9 S/ g% y: _
   function render_site_wide_notice_page() {
% {5 I' k7 \% i' p1 ^- S( }! s1 t$ w      // 渲染后台页面内容
+ k5 X$ q9 W9 o6 Z' b      echo '<div class="wrap">( `: {! ], a, {: i0 g
          <h2>全站公告</h2>
" U% W6 r1 s) u; s  e, t          <form method="post" action="">
# l$ k' {8 v+ e6 h6 \              <label for="title">公告标题:</label>
0 R2 I6 a4 _; v! ]& t( N              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>
$ s3 d) O# Z4 W! \% d              <label for="content">公告内容:</label>, E8 ?0 l+ `: e& Q2 e6 o
              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>9 ^4 p/ D8 s6 [1 z- ^
              <input type="submit" name="submit" value="保存设置">
+ T8 Z" O+ u6 Y; d          </form>! s6 d5 l$ o9 Y2 Y" y9 ?" d
      </div>';
4 L$ A* S& V: j7 N% [7 M
! J+ z- b0 U: n) W      // 处理表单数据/ D! Z+ ]  \- p. x7 _5 j
      if (isset($_POST['submit'])) {' g9 }2 D& t, t6 d$ \8 ?
          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));  c) J8 t$ c5 k, p5 V. s6 D6 M3 w
          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));
; O  \8 M; s  F7 `/ ~' T9 u      }4 w& q0 R7 f5 q: ?( W# ]6 s
   }
$ Y. e8 V0 z; ?) w/ T   ```
: g! e; e' F! K, R/ k( t1 E/ c/ d7 V) t4 G: |: U
   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。: ?+ E6 L! P1 }- B+ _* a/ u

6 N4 s% J' v8 c0 u8 F* q; D3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:( u# g1 |/ v; J& P9 |
& U6 L! S1 h6 _" R( `5 @3 X) H
   ```2 M( A* d" D" @3 }
   <?php7 I) N2 j3 K& I  \
   $site_wide_notice_title = get_option('site_wide_notice_title');
. V/ X" c( {6 R* @# h) [4 n   $site_wide_notice_content = get_option('site_wide_notice_content');
6 E: F8 k9 U. T+ W   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {
$ Z2 J  M& {/ F# U8 H       echo '<div class="site-wide-notice">';
" {' l; T$ T& q" `! J       if (!empty($site_wide_notice_title)) {/ Q' {3 G3 P+ {- L4 t  u
           echo '<h3>'.$site_wide_notice_title.'</h3>';* {& I5 g' W+ w. [
       }: @; k1 X9 z  ?( d0 A! Z+ r* b8 q
       if (!empty($site_wide_notice_content)) {
1 {* ]0 B3 o' H           echo '<p>'.$site_wide_notice_content.'</p>';* X) v$ c# T) A! _
       }/ E5 O; P: q! W9 _- ]0 a7 m
       echo '</div>';
1 f5 W; d' G8 H( g- o! ~& Z   }
: `) w0 k) v8 d! l3 i   ?>
* m6 l- ?( P: ?9 t9 s0 Z/ G# {; V+ g   ```
, J' ~# a$ u# H+ |! B
3 C3 S; |# E4 n+ V3 ?/ C$ V   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。) w: A% A& h9 P6 I* r

9 ?4 T4 y% p: W: P- w4 J" }6 Q请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

335

主题

520

回帖

3419

积分

管理员

积分
3419
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?, b, w0 p& n2 q5 N

6 W1 R1 I2 t# p8 y您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:
: T* A$ J: b5 }- A# z. H) {  ~# ?6 E& I8 k) E$ x
1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:
% q5 ^+ H# F; V; u5 V1 q
2 H, m* Z# @% L5 T7 P, Q: Y```
- P7 y: ^0 Q* lfunction create_custom_post_type() {
3 l; @+ |' r, h6 A; G    $args = array(3 ?) w2 r% j& E2 m- z, b
        'labels' => array(( L8 D) X) H# e- I
            'name' => '公告',
4 k9 M2 Q$ C; c5 n, }: q3 ~            'singular_name' => '公告'
* R% h3 w3 L% {6 E% f' q$ r        ),) {) ~7 p1 G# a. V  \4 o# {+ S" Q
        'public' => true,- M* ^0 J: o0 o+ ]% X  ?% F
        'has_archive' => true,
6 R3 p9 Z, ~& t1 @6 |2 u* w' K        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
1 J' X- {) h3 |1 i2 r3 X        'taxonomies' => array('category', 'post_tag'),- J& Z, \4 P& g
        'menu_icon' => 'dashicons-megaphone',5 B* m4 z5 g4 r
        'menu_position' => 5,4 b& k! b6 r, R6 @$ p) T
        'rewrite' => array('slug' => 'site-wide-notices'). _7 v/ @4 k2 L
    );
6 B5 s& @( u, n0 L& W    register_post_type('site-wide-notices', $args);
, C6 Q* `1 f9 M! B}+ I2 G4 I0 ~8 m) e/ W4 x" L) W' W8 e
add_action('init', 'create_custom_post_type');5 F5 D, ?% ~7 |9 h- P. n
```: t* }5 S& s  x8 N

  h1 V8 N6 g3 N; K2 z* Z在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。4 v7 ]7 G+ \7 E( n; ^, U1 o0 c/ ~; W
! M' c7 E& j& [* f! r7 t& m5 q& L
2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。/ g0 A  t. H; w# S) V, c. M, N1 g0 y
+ W) ]9 F3 K  ^
3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:
& ^+ {0 K  A; ]! L! i! T
7 o. K( _3 T* w% E/ [+ b. ?```
$ |3 l8 \/ K0 ]! h$args = array(
2 d6 J( u: a8 B8 C& ?5 E! t* E    'posts_per_page' => 3, // 显示的公告数量
5 o. g, u" }. z7 d. |    'post_type' => 'site-wide-notices', // 公告文章类型
9 T; [% h' X. K+ l    'post_status' => 'publish', // 公告状态  I! \$ a/ ]; `7 ^1 ?
    'order' => 'DESC' // 排序方式
& {' }1 t3 K" `% t- G5 b9 |);9 n* T: B! P# K; k, p0 j! _

, G3 I! Y! [- h" o8 E4 G! B/ ~$notices = new WP_Query($args);
0 ^3 J) ^( }0 f/ N$ dif ($notices->have_posts()) :0 B4 Y, Q! ^- I2 Y0 D
    while ($notices->have_posts()) : $notices->the_post(); ?>
/ a: g" D% c3 e+ N  Z' W        <div class="notice">
7 F" n8 C3 i6 l            <h3><?php the_title(); ?></h3>! G2 \9 \5 o" p! i& z9 Y
            <div class="notice-content"><?php the_content(); ?></div>: x# J/ p7 A% ~& i
        </div>; P+ h$ ]" }8 y- S
    <?php endwhile;% t( [, o: _0 t& b6 j0 z1 ~7 \; l
else :- R* w. d2 M0 \) Z6 ^
    echo "暂无公告";
! D4 a+ }* L# b# ^) Zendif;. }3 j$ A: b1 n" q" d# k3 V
wp_reset_query();
! `5 O! h- n! u```6 ?, ^# D( F6 g+ W" E- K$ M6 O

' `9 r; I2 K; S2 `, `1 h& i- m! s这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。; x: \+ F4 U6 c

9 {1 N+ ]1 }) x9 k以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

335

主题

520

回帖

3419

积分

管理员

积分
3419
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?8 R$ J. S* O: Q+ e2 |1 Y  a" j

( y% f2 \) B* t! h4 w" o如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。
- e; Y: h4 _: g: D  ]  Z# E, [( {2 X" T' \' a  I. j1 K
以下是创建自定义插件的步骤:
3 q) Z% N( M* [$ C+ H9 l% j3 ~9 }- w  j( w" Q0 t, @
1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:4 Z9 M' }4 M, p4 V6 c# L( D* `: {

* @, `5 Q8 Z, o3 X   ```
: p' `: a1 a7 L/ f$ H( A8 ~( _: T   <?php
) j) g& V+ i$ ~% P  U- c   /*
1 d. b# }+ @- N: I$ [9 Q" i   Plugin Name: Site Wide Notices Plugin6 `0 @1 G- u/ d
   Description: Adds a new custom post type for site-wide notices.
( _1 s: ?$ N3 ?5 T' h5 g' @4 ]   Version: 1.0
% t7 h% \* F4 n; Q9 d   Author: Your Name
2 K! g( R" X; g   Author URI: http://example.com+ w# q9 d5 w1 `7 Y5 ?
   */! x- {0 k6 X, G- A, B

' P# v) u' C( x( u8 `2 N+ ~   // Add plugin code here...
) n$ Q) Q/ M% h$ y2 G2 W   ```( x3 G7 y) e! v6 D
9 G# i( A: t/ Y9 W$ P; M
   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。
6 K9 v9 R8 P2 e6 R$ W$ S+ S; n6 d8 r1 Z& T0 p9 ^5 A; N
2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:, x/ E$ T& P: ~; f4 b3 z

$ c6 T  Q; }# y* V/ \1 E! U6 t   ```
+ W; u! h4 `, T- v   add_action('init', 'create_custom_post_type');
. v7 D  _9 k8 @9 i$ H% u   function create_custom_post_type() {
4 x* J0 g* n) @      $labels = array(
. F. O; D+ t1 k- n1 I          'name' => 'Site Wide Notices'," G) E& g% A& p3 h$ Z
          'singular_name' => 'Site Wide Notice',  t% p1 C, g' F1 C/ e' ?
          'add_new' => 'Add New',% F3 _- Z& ]+ Q
          'add_new_item' => 'Add New Site Wide Notice',
4 _9 f0 m. z2 [; o6 M& a" f, P7 C          'edit_item' => 'Edit Site Wide Notice',9 E# N2 x: a1 U& }( w  j3 _
          'new_item' => 'New Site Wide Notice',
" W" ^( T$ h. Y! J          'view_item' => 'View Site Wide Notice',
' l  u) e* R; N+ p; R* K          'search_items' => 'Search Site Wide Notices',! N2 D1 }* _9 U2 C! L4 {! F! F
          'not_found' => 'No site-wide notices found',
3 U1 ]; {/ X3 x/ F+ L          'not_found_in_trash' => 'No site-wide notices found in trash'4 c" x; |5 i( A1 y, k& g. |0 S: @' J
      );, P9 z( I! x) X
& s* [, E1 V9 g" ?! }
      $args = array(
# P3 {1 ^& K) n; ^- N1 L          'labels' => $labels,
  p! @. r! \9 P4 Y$ {% L          'public' => true,* m" F- y% s" i! Z$ D! V- ]: u
          'has_archive' => true,
( v, ?8 w0 e( J# z1 y% W2 l          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),2 k7 n& k& T! F7 ^% F9 _) U; w
          'taxonomies' => array('category', 'post_tag'),
, H6 d% @0 G, B3 _          'menu_icon' => 'dashicons-megaphone',. v/ h$ N4 l7 a5 d4 ^& l% ~
          'menu_position' => 5,, y" L" ~! m% o
          'rewrite' => array('slug' => 'site-wide-notices')
$ [# [! {0 @7 z      );: ?! S; d; [) ^2 e1 i
/ s! l% t& e( Q9 ?
      register_post_type('site-wide-notices', $args);
. t+ A: F' D3 z  d& K( z   }
- N8 @0 i! A  x8 f$ q   ```
# J' i$ ]& _: z) ?
8 G, B2 O/ w0 J. e. g% s) |! e   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。
8 ^' Y5 e: i0 U: h5 I' j) M" G
3 n# K+ U7 l' N* S, j& r3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:
( G/ s7 H! r+ N8 V3 Y: F4 ~0 L8 L( q* A& a$ ]7 p& l( m$ c. M1 A
   ```
1 i9 ]0 Q$ x  R& {6 s   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');9 [# r8 E# V" U$ p9 h, c* ?
   function add_site_wide_notices_boxes() {
$ [) x7 e# D# d2 C      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');
1 Z# J4 e6 I2 A$ Y4 C   }1 }4 g, M, x# p- j" u  I
& b" T4 @) d1 D/ L1 m
   function notice_details_meta_box($post) {% J& I. A4 h0 l2 k3 `
      wp_nonce_field(basename(__FILE__), 'notices_nonce');2 a4 ~4 [2 m5 a" O
      $notice_title = get_post_meta($post->ID, 'notice_title', true);
  n) [# h: `  o+ v' M/ [+ h$ W      $notice_content = get_post_meta($post->ID, 'notice_content', true);
8 Z3 Y/ o2 F3 S7 x/ R' ?, H      ?>. V: |- H- L$ I$ P
      <p>
3 f% L# L3 B  L7 N          <label for="notice-title">Notice Title</label><br>
+ ?2 m6 L  \* B( v7 k% z7 J3 B          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">
) h& a6 e( |6 r" n8 J      </p>6 ^3 u8 {% c! K* y8 ?* l
      <p>) K3 D2 T; k$ U1 H! x' S
          <label for="notice-content">Notice Content</label><br>
7 {% I) V/ C# Q* o" [% }          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>
& d1 E: H# {+ o0 b7 C& y) e# z2 R      </p>
' e3 U% f* O& _9 T1 ^      <?php5 u. h2 u: H- e! ?! i4 t
   }  V8 |6 t( O, X$ k' H# K

$ s; T" G4 P( [4 H# s   add_action('save_post', 'save_site_wide_notice_meta_box');8 t% l1 ~* A0 ?4 m4 V( G4 V6 @) Z
   function save_site_wide_notice_meta_box($post_id) {
3 {3 e9 t' }) H2 ?      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))
5 s9 ?! Z0 \+ j: k" }- R, M         return;+ r3 F. U1 I( c/ _
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)
3 q3 m1 h. g$ d* s, h3 ?         return;
1 [% `9 t" Z# B  A9 _3 W
+ C1 E( U/ z  j4 d3 q      if (isset($_POST['notice_title'])) {
8 l( e" V! j5 B$ O" C          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));- b9 O  y  U+ h/ Y$ [& @' k$ X
      }3 k. Q( c; h/ l2 E8 J# J8 S( P
      if (isset($_POST['notice_content'])) {  h: V/ x$ |2 l  i
          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));
* C* `' z. ]' K* x0 W) H      }
; g3 f: C9 a  V- C# X3 l/ j. I   }
0 k3 P+ ~; ?" e9 c5 o5 p. w   ```5 d; g9 C: V4 N- t

& h  S. S: ?! ~: [, }& k% d   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。3 R- Z/ Z' F7 S# a7 I

, ^* T2 n4 d; F' C8 I1 k4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:
: D' e/ m; ~3 d1 A
4 j5 u! L* L6 {   ```1 y0 `1 {% K/ B' K" R
   $args = array(5 C% P& m) l+ o- q2 [
      'post_type' => 'site-wide-notices',& K. V! J6 h/ }: V- Y3 c% o* w
      'posts_per_page' => 3,
5 T( p+ V9 M4 W" W      'order' => 'DESC',
5 i. j9 Y9 E0 p      'orderby' => 'date'
9 g( w) h4 Y* K# R   );6 ?+ V9 p. S& ^
   $query = new WP_Query($args);
- _2 D. B& p- i; p; C  n   if ($query->have_posts()) :' S, {& Z1 o7 }2 {5 j0 U
      while ($query->have_posts()) : $query->the_post(); ?>
* h) w0 R8 I" g' y# h$ t8 A          <div class="notice">7 z, y: _) @) t
              <h3><?php the_title(); ?></h3>6 t! E; o( u. Y. G" f& n; j
              <div class="notice-content"><?php the_content(); ?></div>
. u/ M9 d! P% i8 G: B& y9 k- F          </div>
, H8 X3 Q6 H2 O4 o$ s' v      <?php endwhile;9 ~  f2 G# V1 z( X5 r
      wp_reset_postdata();
% k# s5 M8 [& h8 r9 ^5 k   endif;: G' Q  P9 O. j& \$ V. T/ u
   ```
: v- B' s: j$ m$ I$ R. q  @7 ^
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-11 03:31 , Processed in 0.090548 second(s), 4 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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