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

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

[复制链接]

334

主题

519

回帖

3402

积分

管理员

积分
3402
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:
& _3 ~% N+ j* i: I1 z8 y% b# ], V, X- |
$ v' x$ ^; N+ p% J( K' A6 h1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。. d$ |* }) l3 f; Y9 ]: D) W% ^

# I5 ^/ M' {2 S2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。
/ T  V) L$ _1 r6 ~2 y
- v  w7 v+ z+ u% J: c4 q* k# u3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。, ^$ U5 V& o) }. T2 c" j
% a, h$ T0 Q& ?
4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。
. F9 _2 h- L' ^) `6 c+ @& x. _# B3 r4 \; ~: L
注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

334

主题

519

回帖

3402

积分

管理员

积分
3402
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?
2 E, e7 O- ^6 f* X6 e' x, E, e. q1 z& f) u& y- p
如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
; c0 X5 T  X; ?. x8 Q7 T+ @
  q6 g5 ~( `$ q9 ~8 L1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:
, @- y$ Z% B( \& J1 Q$ Y) Q5 z3 l2 X) H9 {1 }' [# H
   ```( T, M/ J7 R& u6 B& m% r. a3 E
   add_menu_page(
7 X. w9 T* r' S       '全站公告',: o% B; C$ b$ }4 w4 P8 _
       '全站公告',; Y  Z+ E' S  M
       'manage_options', //需要的用户权限( x9 q# Z) }- n
       'site-wide-notice', //后台页面的 slug
1 V1 x- H; [0 V' X9 R       'render_site_wide_notice_page', //用于渲染后台页面内容的函数2 B3 r. `( ]( q. w- k
       'dashicons-megaphone', //用于显示在菜单中的图标
4 i) o1 [. t1 f* H3 x3 d) z5 J       30 //菜单项的位置2 @0 T2 F/ J  q% X8 G
   );" K  }! S& N1 p+ ~9 K
   ```
# l( Q9 d0 Y# w) q0 a' {7 o: ?* |3 c
   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。& n" n4 K1 }2 Q, Q

+ E! m- C, C9 h8 r. n1 _" R# k; [7 Q2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:
% D+ D/ [5 M5 y& H9 I! E, @' k3 m2 Z% \
   ```
* v. e% B; s7 q. s: y+ J   function render_site_wide_notice_page() {
1 X/ ]7 l/ a8 ~, p4 Q      // 渲染后台页面内容6 \, R! H* H! v- K, h
      echo '<div class="wrap">- K0 P( Q% u) b" G. h, {
          <h2>全站公告</h2>
* j( z6 j4 |% _, b4 }# Z5 }          <form method="post" action="">
' b' H! `% N8 \  I, E/ E              <label for="title">公告标题:</label>+ v4 E( T% S' A$ z# L
              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>
) k/ l( O* @1 k              <label for="content">公告内容:</label>
$ g- f% \- L4 F% h8 A& P; s              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>9 k8 M3 |2 i- d3 e3 Q' D- m
              <input type="submit" name="submit" value="保存设置">8 h( a" C: H7 N" q
          </form>4 O7 \) _( P9 m
      </div>';6 s8 T% `& a; \$ h2 ^

) y  q! W: R+ F  L  k4 P      // 处理表单数据4 P1 j- h- S. Z3 D0 T( x
      if (isset($_POST['submit'])) {
; h# T- P' b3 h/ ?2 P          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));
" C* w( E! {4 q3 F          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));% c& X, @/ B" z, M0 l5 j+ V* _' j
      }- `; ]% |7 T$ b/ o
   }+ c. S: ^$ y+ @
   ```
3 u+ ~) [& j# i0 w% S9 q  g  \- k! y( r9 l/ a
   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。
9 A# I- J  ?5 r; k2 X% E5 `8 z% R7 X; ~8 N; J" C0 S
3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:* x. |* n7 b7 h

) s9 X8 G4 ?& h4 t$ A% D   ```
& O5 `& A0 L, c! T. V   <?php
. p- w* ~$ f: L7 q   $site_wide_notice_title = get_option('site_wide_notice_title');, k5 j8 k# r% F. g
   $site_wide_notice_content = get_option('site_wide_notice_content');9 L$ @% K1 z  h2 G$ a
   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {
# _' j- B, U( g9 Y% o: r5 h/ P$ y       echo '<div class="site-wide-notice">';
- y4 v, G2 L6 M       if (!empty($site_wide_notice_title)) {7 e9 k  u6 ~9 q+ n& x
           echo '<h3>'.$site_wide_notice_title.'</h3>';
! s4 A& u) \  H$ F       }1 k' t8 p; n- f) J) p* F
       if (!empty($site_wide_notice_content)) {1 w0 G: y* X5 i' S0 a( U  e
           echo '<p>'.$site_wide_notice_content.'</p>';
9 t4 ~5 `. g, y       }
# \/ h  R  B4 n* G/ q       echo '</div>';( o) v( W- s3 D+ Q
   }3 S) }5 x) x8 P$ I! s3 p
   ?>8 B$ |  A% l" [5 _  H& A
   ```
0 P$ L1 S) V# i) v; L6 P7 t
' k! K9 B3 _8 {  y" L  X   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。
1 s, [  B0 a3 ]+ C6 W+ V& [& @5 \5 ]% g+ c1 n7 b0 d9 w
请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

334

主题

519

回帖

3402

积分

管理员

积分
3402
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?
' K, C! l" p8 }4 z( W- @/ D9 Z; f6 ?) A- E/ b
您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:
5 U' k: p% A  N1 U8 r" z: ]( v( `9 F9 z
1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:
( c  M+ D8 M0 s  w, H; |1 n
* _  S1 ~3 A' p" S" V```
3 A7 m1 ^/ [& p7 X, \function create_custom_post_type() {
; T. k+ I& ^& s2 q3 A! i  F    $args = array(
( v3 b( x. i/ }4 R7 l( V        'labels' => array(
0 S# }+ k9 b* s9 @" J; s            'name' => '公告',
; @' j; m& v0 H0 n, R0 j9 n            'singular_name' => '公告'3 G1 r1 u$ s* E8 W+ X
        ),
4 {8 B; b: C% x; ]        'public' => true,/ n5 h( n( {7 h; P
        'has_archive' => true,
; h1 H) v$ F# i, E  g        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),- Y6 i/ E- ?, D4 n8 K" m
        'taxonomies' => array('category', 'post_tag'),
' l- g+ M( ]1 w$ z4 ?        'menu_icon' => 'dashicons-megaphone',
" A: H6 N3 Y) h/ E- U/ _- |        'menu_position' => 5,1 e" S8 D! V, {9 a* b8 Z8 X
        'rewrite' => array('slug' => 'site-wide-notices')  Z' Z; d! B% ?, f
    );
/ `# U! D9 B+ b# ]/ q: e  q    register_post_type('site-wide-notices', $args);' {& u+ n6 _- R4 v
}/ E+ w0 c" a" g, p& l$ f  i
add_action('init', 'create_custom_post_type');# G3 e# C7 v3 s) z' I( m- J
```
( z& D; w& z" c3 p; f! x/ U
, k* x/ I: B0 [; o0 r1 @/ J在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。
- K: s/ E. T8 d9 X1 |7 @& N
/ U8 t. E' _; [9 N' _: ^% |2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。
: Y) v: p% I' ~! ?0 @! \3 ~+ |; M0 G; C  T/ b* i
3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:- v* b( P, D, G* g+ D

& a3 w' i3 r5 q: ~, @2 L```7 S$ `, g& `2 K( q$ C9 C
$args = array(
( d9 b' T+ _# F, Z8 g% A  s5 c& K9 q    'posts_per_page' => 3, // 显示的公告数量
& I7 R  s& Q( m8 x" s    'post_type' => 'site-wide-notices', // 公告文章类型
+ Y$ Q# h# }* N4 E# Z" _4 Q    'post_status' => 'publish', // 公告状态
! R* [( |& X& ?4 Z- W, I2 |    'order' => 'DESC' // 排序方式: A1 Y  ], B( z5 t' D
);
7 Y8 |3 _' D& o* l8 C- \* M. \2 S7 ?, c* h; e( T. i
$notices = new WP_Query($args);8 X9 N6 [3 u. ~8 o( C
if ($notices->have_posts()) :
1 b1 H0 r- h! S$ x) a& p: L3 h    while ($notices->have_posts()) : $notices->the_post(); ?>9 z7 E& ]8 [. r; a+ `5 d# }* {
        <div class="notice">9 L  e8 }# D: E! H; |( s+ N1 H
            <h3><?php the_title(); ?></h3>+ @; Y. X" t' N6 a7 t
            <div class="notice-content"><?php the_content(); ?></div>
7 A+ f3 R) z2 F# h3 r        </div>6 X- Z% P% z& ?% l) J( v
    <?php endwhile;
. w- Q8 D3 X/ I& Y& |else :
9 c( N+ F. u4 D; Y9 p5 T    echo "暂无公告";  g+ ^( U& B+ h; E1 d
endif;
  v  B2 H- Q7 o1 O' i4 Y9 W- ~wp_reset_query();! @! V6 s' N. P4 I
```
5 E7 A9 ^$ w! n+ s) a$ v8 e5 u# L# k) t
这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。
# a/ V3 P/ A( J$ _4 O* G+ u1 t+ Z) j( Q3 H# N8 b
以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

334

主题

519

回帖

3402

积分

管理员

积分
3402
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?
! c) l' m+ \7 L4 j, W' D! h' x0 G) i7 g
如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。; m5 W! y8 Y& L/ @
  U1 k- n# W4 H' \9 R- r2 z
以下是创建自定义插件的步骤:0 J& Q8 \9 U3 C+ p9 s

! j% \( v4 H$ P' G( j0 ?" p1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:
4 m+ M* I% P4 k. f3 K. B( [
9 ^7 L# {! S) B& P   ```
5 G% u" |2 P5 r0 N' |  z& |7 T! E   <?php  r  D+ s3 r4 z; O: F/ q
   /*
7 d, i1 P* b. Q% h2 p0 i# ]* v   Plugin Name: Site Wide Notices Plugin
8 i8 H$ u$ _6 B* h4 H- ]   Description: Adds a new custom post type for site-wide notices.
! z1 }6 \. E5 ^5 t2 k- R   Version: 1.0; e; b0 E# \0 V9 {2 q. _
   Author: Your Name$ U2 X  ]- X* R9 L. g8 n1 O, \8 X
   Author URI: http://example.com
/ i& O' W' @9 ]; _: e   */+ l. F) o. w$ v# t: M; i( Q6 F

* y3 U. l4 @( ^- X' W   // Add plugin code here...4 M" ]+ f$ a. Z9 C. |+ u6 P
   ```
# r8 x& e; P, ?3 u9 q5 z& D0 i4 c% ?* h- o& }  j0 P6 y5 k. C2 t
   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。- f5 |% V; C( L+ E8 m+ \6 Y
9 Q: N- R8 A7 I, U
2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:" x# r" z( j  Q% F
/ y2 Z7 T8 S( \6 d4 m4 W( q; r
   ```% D8 G. e# l4 ^& \6 ~
   add_action('init', 'create_custom_post_type');
) T, c2 y/ A' k' {4 {   function create_custom_post_type() {1 p* Y. S4 a: W7 k. ~  m
      $labels = array(
; F3 R7 w* @" _2 F2 G7 Q          'name' => 'Site Wide Notices',- P7 P% z5 @$ t( N
          'singular_name' => 'Site Wide Notice',# y9 V+ T7 u2 W/ ?0 x- l+ P
          'add_new' => 'Add New',# u) Y/ I' Q. Z
          'add_new_item' => 'Add New Site Wide Notice',  P& Q* r: X! O( R, k
          'edit_item' => 'Edit Site Wide Notice',
7 a) H( ^1 i- u0 d4 @7 M          'new_item' => 'New Site Wide Notice',& F. F9 L" ~7 [! |6 l+ Y
          'view_item' => 'View Site Wide Notice',
; e( C4 @* @) L0 {6 }          'search_items' => 'Search Site Wide Notices',) i5 v& }5 ?2 F+ k% V3 ^( \
          'not_found' => 'No site-wide notices found',
, F/ [: r; m: P" i0 M+ `9 S          'not_found_in_trash' => 'No site-wide notices found in trash'
8 P. w1 I8 \# K4 K5 s% I$ ]) d      );- M3 Q* O' w: o; g! n8 N
! E5 ]8 q4 A+ r+ z
      $args = array(; X: F) \2 p  w0 z$ [; T1 B
          'labels' => $labels,! _$ f% A7 b7 l! n0 j0 I
          'public' => true,
: C- o5 C( W; \7 B( j          'has_archive' => true,
% |9 Y( Z# ]! @4 }          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),9 f% n3 `7 v1 }, x+ {1 `" g  t
          'taxonomies' => array('category', 'post_tag'),: }: f: d2 D" b+ ?1 c  ~9 B
          'menu_icon' => 'dashicons-megaphone',/ [% G1 Z' D5 H  I! f5 t
          'menu_position' => 5,
9 h/ a* ]- V5 W7 c          'rewrite' => array('slug' => 'site-wide-notices')
0 Y$ I) I3 U0 `6 G; A8 h      );% Q9 Q) V/ ^8 z# v! i8 Y
: [0 e6 j" N+ z
      register_post_type('site-wide-notices', $args);
% S2 r$ N+ s! `1 x8 i0 D  V0 d% t" p   }
  E; }: z* k4 Q8 j   ```& ~2 s/ F% R/ i& z2 w$ M
9 \* F- i7 A6 S
   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。  b3 M3 w0 D: o& l. V4 Z  G
! O7 `0 W! ?  S9 J/ t7 V  s
3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:7 C8 Q9 u7 H7 A; ~7 L

5 ?1 j) \5 _/ M   ```
* d' I. e& u0 |! T: h   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');
, r0 V+ V8 ]# Q! k9 _0 b0 j; g   function add_site_wide_notices_boxes() {
/ j# U6 Z) Q! T7 L7 Q/ r+ K      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');( D1 q2 [5 f1 M8 |' v: p, q% e9 t1 x
   }. ?% u7 ]- S1 L. A5 p# ]
' Y$ [* ^/ L) }
   function notice_details_meta_box($post) {! z, v  G  c" F6 H' F5 j
      wp_nonce_field(basename(__FILE__), 'notices_nonce');
  O- o- y3 O- h1 n+ i3 v& x- e' S1 \: n      $notice_title = get_post_meta($post->ID, 'notice_title', true);
# |3 d: `- |1 c      $notice_content = get_post_meta($post->ID, 'notice_content', true);
, F$ |4 Y/ I0 v9 C4 ^+ X* x4 z      ?>& z5 T6 X. _8 a! U+ q/ G! c
      <p>1 S$ X4 b5 X; f, c
          <label for="notice-title">Notice Title</label><br>
. _5 ]1 Z( x3 d0 R2 @  W1 [( B          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">( s$ F, X% L" A# ^
      </p>2 c. u( V* j- b) L
      <p>" J0 n( z* w3 e& r
          <label for="notice-content">Notice Content</label><br>+ Q3 V1 n/ d5 z; s
          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>9 Z' ^! a" H  A, y# _
      </p>
8 ]* m/ F, X3 l# g3 _) r      <?php
8 O% S, u! J5 q2 b+ G   }
; o% l9 W: b5 z2 X& ~: r/ A7 F/ K+ G) }" R1 G6 @, E( z
   add_action('save_post', 'save_site_wide_notice_meta_box');1 f. N6 s2 H4 B5 J5 b/ G# N& H
   function save_site_wide_notice_meta_box($post_id) {, g5 ?: N4 k/ b  A+ X
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))% m3 i6 d4 Y  [' j0 H: p
         return;( O9 z  T8 ^/ `3 i
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)
; j/ _* l7 x8 f. [         return;# t5 ?; m4 K: o( ^, |

% f1 x$ M5 N. S) A      if (isset($_POST['notice_title'])) {1 n, @1 D* \! ]# O& K
          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));1 p+ N/ p4 Y) v( }
      }* R* ]% d# t4 Z7 ]8 s
      if (isset($_POST['notice_content'])) {
7 x6 F# [) M% j7 A          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));
& m3 X: L% U+ X- N8 q8 u- ^2 S      }9 Y6 ~' A6 _/ a3 O. ^! T
   }
) X7 w: Q( r- l% L; a   ```
" {1 B6 T8 j1 f# V, y& z8 v$ G! D/ ^/ o3 J; Z  o% j$ _
   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。: m2 ~! ]4 B. [6 n) ~
2 |. i. a0 ~5 z8 X1 {1 n3 z
4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:" T; U. p  `8 H# h/ @

! f+ i, u' }- t5 f5 c* ^   ```9 k, {( q; u# b) I: B
   $args = array(
% y- E, C, S" Q! r' z      'post_type' => 'site-wide-notices',$ L/ ]8 e7 x8 B. ?% d  Z
      'posts_per_page' => 3,
, E8 r. i. n" N; y" M      'order' => 'DESC',
& Y6 _: l7 y8 r4 M1 |( r* o+ j: B      'orderby' => 'date'
; {/ s5 C2 A- V# }* V5 X2 Q' N   );. d) o. P9 `: Q' ?  k# u1 |
   $query = new WP_Query($args);
% O9 E4 \8 B8 K/ E. l+ C+ h9 j2 `   if ($query->have_posts()) :+ f+ A$ y: k1 N2 d2 I7 S0 P9 ~7 i
      while ($query->have_posts()) : $query->the_post(); ?>8 Y5 }6 u6 i1 l$ y" k2 ~
          <div class="notice">
6 _: H' C2 c6 Y, ?              <h3><?php the_title(); ?></h3>
/ ^4 l1 b! V5 K7 W8 e9 M% ~              <div class="notice-content"><?php the_content(); ?></div>/ W( u1 K$ }! B4 h1 |) J' L$ W
          </div>
) M& M1 c& ?# _1 S' o      <?php endwhile;
% Y3 }9 G+ C! T/ L' h/ Y      wp_reset_postdata();! O4 ]. y- j. e
   endif;
7 E) a3 Q( ?8 v7 F   ```
& Q( Q, f  [7 o2 [! t. @; Q0 z" t" z6 v. R
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-6 01:59 , Processed in 0.089753 second(s), 3 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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