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

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

[复制链接]

364

主题

576

回帖

3835

积分

管理员

积分
3835
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:
0 u5 Y* ^$ h$ }
6 v8 s8 m  C& l2 b- Y( N1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。
/ E" p6 [" s/ S6 V* z9 ?' m+ v
# P* a1 I8 S' H; ]1 R: T2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。) ^  r: s; J5 ^/ K$ o( N  d
, `* N) \% Z- X
3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。
4 j5 j; ?+ d5 m* |$ z! l0 C3 V' W' Q  b) {/ M* l$ S. e
4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。- i, y9 h9 T# U/ V+ z, B) o9 r

$ ^0 e" P+ ^5 {9 y8 V; a注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

364

主题

576

回帖

3835

积分

管理员

积分
3835
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?$ _" ?* X( f- a! q0 q7 J

+ z: H3 b; @4 T4 e/ u6 E如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
* N. d( V) ?9 `
4 t- G  X; a/ d$ G* R- t) P1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:
% `, g$ @0 H( f7 F5 h# D# P' i- ?: k0 O
   ```- t! d5 Y# V  L/ q% F
   add_menu_page(
5 N7 a' M! ~, @+ J' o. w* J0 j1 r       '全站公告',7 |, Q+ `1 r1 T. u' O3 E0 g
       '全站公告',: S% E5 ^8 x! ?. O( f1 n" O. P) @# a9 H
       'manage_options', //需要的用户权限
; n, g+ f) V7 O! c: ~7 ]; x/ `. b       'site-wide-notice', //后台页面的 slug% ^. w' t4 E5 H3 t) ^. A
       'render_site_wide_notice_page', //用于渲染后台页面内容的函数
% `; ?! E& X8 [       'dashicons-megaphone', //用于显示在菜单中的图标' M& q7 d5 X  b* d
       30 //菜单项的位置  z7 _1 U- v- n' H% {( ^( N3 Q$ p
   );
& D/ k/ j/ P7 B9 G  t/ L   ```
1 C) e. s, z, {, C* X. B; T! ?1 Z5 |: V5 m0 i- |# S0 w
   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。6 U1 p1 x' v0 ^" {2 m" q
6 m- Y/ m- @- `/ F$ q
2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:
/ h* Z  g* X! _( v, Z6 t
4 ~7 x, i$ c( |- M6 l   ```# t6 ]2 n  B1 z, o- p
   function render_site_wide_notice_page() {" q5 F. f6 }0 z& l
      // 渲染后台页面内容) L$ V1 `& H) k$ M# q8 L
      echo '<div class="wrap">, R: X" X6 J# `+ T
          <h2>全站公告</h2>
  a, B- T3 b* a# U1 @3 n8 z; B8 y, F          <form method="post" action="">
) }; C8 D* ?2 A. @7 g              <label for="title">公告标题:</label>
4 q7 }1 x1 }0 g+ g* s' w2 b8 H' u              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>
5 K0 |6 v4 H, X0 F# D              <label for="content">公告内容:</label>
9 z% m2 y6 u3 S: S/ O. F" u+ w              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>
6 R% t( ]( {0 C& ^& Z              <input type="submit" name="submit" value="保存设置">
2 `4 i+ a/ N% s: D2 v: W/ T/ |          </form>
7 R5 E, ~1 A. J2 {: @! X2 y      </div>';
2 w) D6 e! |/ d& K" @. S6 _! T. A# L1 `* U
      // 处理表单数据
: E  X! y7 C" s/ L) i" A3 Y# s      if (isset($_POST['submit'])) {
. X' Y: o4 ?$ o; |7 t) M          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));  |% Z- O; e$ ~$ Q+ j, L
          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));
5 w: \3 R8 y+ t# q      }
: f6 R( F7 l$ L( V* I* V# t   }
1 J6 W: y% r/ Z/ ~4 s& b   ```8 N1 W+ H7 b7 P# q

, C) ^- p( j" c6 O2 l& Y* W: l- y   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。7 o  y6 L' K6 Z9 S# C

2 N" _+ o/ T7 _: e3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:' T0 Q3 v5 Q. M- ]

/ Q! j) X$ r+ y6 T0 ]5 e" P   ```/ l% e. H' L0 m1 p/ d6 S
   <?php. `# l4 ]! T: z, M+ @
   $site_wide_notice_title = get_option('site_wide_notice_title');
6 }1 N6 H, r# A  g& O1 B6 @1 O   $site_wide_notice_content = get_option('site_wide_notice_content');4 q* p3 x6 U6 I" L$ d; X- _' x
   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {
% z) @/ g' F8 [3 T# U       echo '<div class="site-wide-notice">';
& B# p' H) L! \) N% `/ @! F       if (!empty($site_wide_notice_title)) {, a1 l: ~3 u8 S3 ~; F: {
           echo '<h3>'.$site_wide_notice_title.'</h3>';
. w. Q5 q5 F0 w/ H       }: h0 o& l1 q6 b7 N
       if (!empty($site_wide_notice_content)) {
7 V4 m7 P; h0 b1 i) `+ ]0 `/ L           echo '<p>'.$site_wide_notice_content.'</p>';* O7 \7 z/ I9 A8 _& B$ |
       }% {3 r$ N! U" T7 z  G! a
       echo '</div>';8 l% c  r3 i" R* P
   }
& N' n4 M* m/ V+ B6 A' n" C3 T   ?>2 L6 |1 p: h" Q" x: c
   ```
6 F/ i  N: n0 w! h5 Z6 E. c- C7 A
   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。. G& g6 {7 Y  i

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

使用道具 举报

364

主题

576

回帖

3835

积分

管理员

积分
3835
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?
) W" P- \; g+ `" ?0 {! m' f- |+ C6 u1 @+ j3 ~
您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:; S5 z- R6 C6 L0 M& Y3 j
5 }! Q8 D1 v6 e' O3 m- K) n
1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:; o. p1 a2 r3 p; k% }3 A
8 R) a( |( M0 q* d6 ~+ \
```6 s' d; O; @) A  q6 B& R
function create_custom_post_type() {
6 p* Y( w/ P- i    $args = array(- F9 d5 {' @: g- U+ \! x( t
        'labels' => array(' c) F, c3 }. g
            'name' => '公告',
% A+ a+ [8 y1 y# \* g            'singular_name' => '公告'
* z# Y( o, }2 a8 S        ),- Q( q1 `& r" |4 A! M" c$ X+ c
        'public' => true,  _  `) I3 y4 t$ [
        'has_archive' => true,
* H! }5 g% J$ Z        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
) p* L- G/ I* J- o1 n) m" u        'taxonomies' => array('category', 'post_tag'),
3 Y' s2 E" w; f5 j5 D' h+ d        'menu_icon' => 'dashicons-megaphone',( o# G) P. [) d/ `: C3 H
        'menu_position' => 5,
3 W1 R: p' W2 t& x        'rewrite' => array('slug' => 'site-wide-notices')4 t2 T5 ]. D! H- a
    );
+ T% U3 ^( x1 [    register_post_type('site-wide-notices', $args);
3 d& E: T5 T& V0 q1 G1 c}
3 E' o. d4 D; @  Zadd_action('init', 'create_custom_post_type');# c0 d$ n- Q4 M  B
```
* i. G' L  }7 ]/ n5 @. C6 T( B; q0 Q/ p4 {) m
在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。
& }/ o& c1 O) s+ r2 F' m6 Z* f( N8 y( R& k6 S7 r% i) s
2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。' o& n- K  C1 n% d2 t/ I* x3 y
0 A$ r- [- ]5 `- a3 Y
3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:5 U7 C. w, Z/ o) V2 H
0 R* o1 z/ C( C4 [+ V8 k4 j
```
! b. \8 K/ M, H5 t4 W  B5 j$args = array(
  j# D2 A# M3 P  q    'posts_per_page' => 3, // 显示的公告数量- _' C$ v! B( X2 j- y" I
    'post_type' => 'site-wide-notices', // 公告文章类型
# E; v0 w8 _1 G    'post_status' => 'publish', // 公告状态6 I* e' S6 M! ^2 H8 J7 N
    'order' => 'DESC' // 排序方式
/ y* m6 {# Y- x* o4 A& });
) W: m0 s8 c1 G  z! Y4 U8 `+ t: V: D1 @. x# N9 U' m" _6 U
$notices = new WP_Query($args);
0 o; U# \* c6 cif ($notices->have_posts()) :; S+ E; e" q+ w  L
    while ($notices->have_posts()) : $notices->the_post(); ?>7 K8 l' [  V, p8 i) ?9 ~1 _7 Z
        <div class="notice">0 p3 b- j* y4 U$ F% s
            <h3><?php the_title(); ?></h3>* m+ c1 O* d& ^- R6 `7 o
            <div class="notice-content"><?php the_content(); ?></div>1 U# b& y7 O* m0 D0 y( a, r! [
        </div>1 Y0 _% F1 [+ y0 C5 I
    <?php endwhile;' y+ a. W7 `9 j7 ^
else :) I6 Z0 w6 O6 w$ e6 h
    echo "暂无公告";
6 W0 I, X2 @$ Q7 m3 f" Hendif;
3 m8 L' }8 m0 w* h0 |0 t2 v$ T  Cwp_reset_query();
" p/ X: R# E( b" \" N  o. f```
- F! ?0 ?( r7 B! F: E$ o
3 F( [8 Q2 L1 s. j2 P这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。
  \  |  b, {& W# L  g* f
' ^/ T/ s: ~: M8 W以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

364

主题

576

回帖

3835

积分

管理员

积分
3835
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?4 h6 O- d! S5 B! i5 f! _
! J9 \* u3 d4 n) E2 Q  C9 i
如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。
+ d. H& U* V0 A6 F& f1 U; B7 E* w/ l$ v5 S
以下是创建自定义插件的步骤:
+ O! ~/ R: n. t6 v" K. b( V& a
9 T* _: k/ ]. ~0 W& @7 ^/ s% v1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:
& k) ^! [1 m$ j$ u4 M( f9 y5 x% i2 A  N" w, U
   ```
% s0 a4 ?! y7 ^; Z$ l7 g( L   <?php
. t" ]* r. r# k, ^; }# ]7 ?% P, O   /*
5 z- t5 \; }( A+ N   Plugin Name: Site Wide Notices Plugin
3 d/ d9 J% t5 g/ u# t, C  k& ]% v   Description: Adds a new custom post type for site-wide notices.( h" {( |( b! C: m% `# l* j
   Version: 1.0
, Y, ]( J# j' @+ t- J4 r2 x9 W   Author: Your Name
5 N0 \3 n" Y. ~. N- q   Author URI: http://example.com
0 k% a# ?# d5 ^- S3 @   */
/ K9 u  M9 _- y0 W
( T$ N6 o# m5 \" B( u   // Add plugin code here...6 I; n$ t- Q8 G( N. ]4 C) N
   ```
' @' ]5 W' D; K* U! U) \% u* ~5 A6 e- s) s! c
   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。
, W; M) l, r5 I8 }6 r" y1 W% `8 G' k9 v. N# X6 \! ^
2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:
$ W: s: d& L1 s1 B0 e
( Q" y. N  \/ j   ```
& o& o6 d* ]: _' ?2 R   add_action('init', 'create_custom_post_type');5 d8 x% V9 v5 ?! q. g) c0 y- R( r
   function create_custom_post_type() {7 j5 H. B: ]1 s8 z, H
      $labels = array(% W6 v* j2 w  S; [6 R
          'name' => 'Site Wide Notices',
6 R9 t* x/ B8 Z4 Q. S6 D' D          'singular_name' => 'Site Wide Notice',  b  y$ g8 Z! K. ]; R) r
          'add_new' => 'Add New',9 h, e3 _: D/ `4 Q) ^5 g: x# T. G2 j& U, y
          'add_new_item' => 'Add New Site Wide Notice',
% }9 v- E9 D+ ]2 B3 u          'edit_item' => 'Edit Site Wide Notice',  x: h, G) ~+ q( {& y; u
          'new_item' => 'New Site Wide Notice',$ R' l# C/ T  S$ z6 y2 s7 T
          'view_item' => 'View Site Wide Notice',
) u' ~" I, M1 `( Y. ^          'search_items' => 'Search Site Wide Notices',
8 B  E( ?) v0 }! G  Z* O          'not_found' => 'No site-wide notices found',
) s$ w) e- B# J. d- z4 D7 \0 ?. X6 K          'not_found_in_trash' => 'No site-wide notices found in trash'
8 Z/ h! }5 e- q/ _+ o      );
" q" j+ ]# q# \$ d) C7 v, w5 k, C, R% y8 C0 N/ j* R4 k# \
      $args = array(
* q& z4 u/ |4 @) d4 P) K- w" N5 P) D          'labels' => $labels,
) V% e* Z$ j) O8 Y/ a2 U          'public' => true,' }0 N' [9 Z/ U( }0 ]0 u' ~
          'has_archive' => true,7 {' U; t* S7 c1 e. [+ k/ l* Y- @7 E
          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
& _9 N- k& R. ~* b1 T7 e          'taxonomies' => array('category', 'post_tag'),, O; H6 L0 w2 b- K
          'menu_icon' => 'dashicons-megaphone',* C8 M. ^. a, a
          'menu_position' => 5,
& r- V- \8 d) {3 V9 g          'rewrite' => array('slug' => 'site-wide-notices')! `7 z3 M, M5 E6 v5 j* g
      );3 G2 a" u& p* y/ M3 m

2 V/ w! X" ^% w2 a( o. R/ P& |      register_post_type('site-wide-notices', $args);2 U4 Z5 E; k. I! @* h
   }1 V9 g6 E% M# {. @* s
   ```
: T6 O, I8 Y$ z9 W, b0 C6 Q; z! E! z7 Q9 G# A
   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。! B% v8 e2 g, J- P3 B! S

; T5 d8 c. y3 `! R! U+ B; U! ^3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:& p  N1 x* J4 [3 \  _# x: b

3 W. k; W# H2 m1 i% H+ ~) @) \   ```
. I( w2 C7 h3 T" v' f   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');
' |: k* P/ Z' j; Z- x   function add_site_wide_notices_boxes() {
+ }% t6 o& K. z8 t, N* [      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');
9 T( Y& y+ o' C% M( S   }# D& ?" k3 l1 F2 u$ ]
% f* f0 H5 j/ V0 N/ {$ ?
   function notice_details_meta_box($post) {* Q  R$ c! s! B8 Q1 ^& O' {
      wp_nonce_field(basename(__FILE__), 'notices_nonce');. u, y; u& E6 _" }8 Y1 u
      $notice_title = get_post_meta($post->ID, 'notice_title', true);
* N  t; K( K' H( `! [      $notice_content = get_post_meta($post->ID, 'notice_content', true);8 a& t1 O7 l5 E  |* C" \
      ?>
1 q* i1 Y/ U6 a, \      <p>
+ D1 ]9 d) w, L          <label for="notice-title">Notice Title</label><br>
3 m9 ?7 }+ K8 e) B3 c/ C4 f          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">
9 d- G9 ]# Q9 ^* R; X2 u0 P      </p># `: s# y% B9 P0 L
      <p>
3 p3 a; J4 Q( B3 v          <label for="notice-content">Notice Content</label><br>, Z0 }, G! b. H9 n3 ~$ X
          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>
3 z' B' a# Y9 o( Q      </p>
' I# j# M2 Z& d; b* V, @      <?php$ r' E! ?0 c7 Y# f4 {7 W/ Y
   }. r8 ?8 Y+ I( @$ o9 `

4 M( t, w) `+ ]% q   add_action('save_post', 'save_site_wide_notice_meta_box');+ }4 f( J( C6 L8 S% C( f
   function save_site_wide_notice_meta_box($post_id) {! h( @0 s) H5 @4 g7 o' r4 N
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))$ ]( S7 [9 n# \2 \' _' l0 _4 K
         return;! p+ f9 r- b* S
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)6 F; ?0 i" A  R5 b0 Y# K" I
         return;
+ B; K  q! F8 `0 X" n) N& u8 T" z* {9 T7 \
      if (isset($_POST['notice_title'])) {
" n! \  J; W8 ]; w# @          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));' \- Y" r+ U+ b3 _' [$ B
      }
2 E  A) Y5 u1 U; t1 V  }, U      if (isset($_POST['notice_content'])) {
& J; _1 \8 _( w          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));
5 |0 p8 R  ~2 }- a% V      }
4 {7 q, H- B. J) j: e3 g$ Z   }
% P( V3 M& \- p& `8 I& g   ```
+ F; t! G6 Z; F  K
/ y( z) v. N, ]   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。
5 z$ E5 g9 z& b, `) }6 Q8 H5 C
  A0 A# F7 q% v0 q4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:8 B- D+ a+ Q* O2 k& X
: W' z+ g! r# z# }- V! K4 N' {
   ```
* b2 P4 \9 U6 |" p   $args = array(4 }. J7 l2 A* U
      'post_type' => 'site-wide-notices',
$ @. I2 q7 C$ C  O, X# T* [      'posts_per_page' => 3,2 t/ ~% Y' N1 S; m; H) G
      'order' => 'DESC',: S2 t/ F  x: l4 a  I) ?
      'orderby' => 'date'
9 I, G. D% U, i3 u3 ^4 }' P   );: p/ e# f1 L& I2 V, b* b9 @3 r
   $query = new WP_Query($args);5 t% [' j9 w' q7 v' u3 ?! J
   if ($query->have_posts()) :
3 K! r/ W2 b8 v- \# W9 A5 Z      while ($query->have_posts()) : $query->the_post(); ?>
& C8 a  r4 Y7 J! F          <div class="notice">
% `2 b% S# I/ V+ r+ |% O# ?( f+ l7 c              <h3><?php the_title(); ?></h3>
/ t6 S2 T4 }+ y: _7 ~; o. L! B              <div class="notice-content"><?php the_content(); ?></div>
- z- i( `5 g/ @) \  a          </div>
6 H  r7 c6 k9 q* |$ C7 m      <?php endwhile;
8 x6 B( h8 G: d; ]7 O0 d( D      wp_reset_postdata();: d! H  v& n- ^" N. O& R9 B
   endif;* J, I8 \% V6 B3 G: ]0 e8 W
   ```: m: n% P' h+ p7 X/ ~5 k8 X, f
# ^9 l4 \* W) @3 D
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-25 06:24 , Processed in 0.182783 second(s), 4 queries , Redis On.

Powered by Discuz! X5.0

© 2001-2026 Discuz! Team.

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