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

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

[复制链接]

320

主题

485

回帖

3140

积分

管理员

积分
3140
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:
- e7 b  w6 v  x* h8 `, a  W) b. h9 m, W' _0 E- _
1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。
  }5 ]- O0 C0 E6 j2 U
: @0 U4 m1 l7 `2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。9 B# [9 X. w) V

) A7 ^4 f1 I7 q! ]3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。% v8 v2 b0 _3 B3 R

% a2 s  E' e+ I8 G/ s& k7 ]4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。
4 _4 G; W2 W5 F* a1 b( W( C0 ?- o) g! [% W; W% H: ^# J
注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

320

主题

485

回帖

3140

积分

管理员

积分
3140
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?
: A9 A8 o' o+ `, K$ l  I! `( L4 J; |! M% o' @( }/ g4 ?
如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
, h  o- k# M! d; I8 n9 u% {  w5 _4 K8 m4 U- O
1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:
5 @% ]6 _) b6 F; _' O
& o: P+ J6 s  h7 U   ```; @& ^" C- x8 q8 V  M& X
   add_menu_page(/ Y7 ]+ H1 i2 m+ V0 d7 A
       '全站公告',
  f& x' N+ }% X  p& h       '全站公告',$ R6 e& D6 V9 k9 @
       'manage_options', //需要的用户权限3 U* P: H: p% Z5 U% I7 z
       'site-wide-notice', //后台页面的 slug; D4 W! c" _8 y( X3 Z
       'render_site_wide_notice_page', //用于渲染后台页面内容的函数( F2 l# B( v% {
       'dashicons-megaphone', //用于显示在菜单中的图标2 F4 Z1 o* Q" [' k8 [4 a" y% c
       30 //菜单项的位置9 y' x4 N- a  K* s# Q7 Z* B
   );5 K. g/ j- A' w6 _
   ```+ R) |2 B! G9 |9 O* s

3 d  m) t6 ?6 s   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。
5 K9 V, Q) E) U; a
* [; P1 ~4 b/ r" b' c2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:& @0 w" U/ m% N( ~1 B- M

: D7 J- t* [2 I   ```
, d1 h( \7 k; F+ B9 B   function render_site_wide_notice_page() {% `- ~" D& u  G& k- k% \0 V6 o
      // 渲染后台页面内容- {! J/ n+ w& g5 `% ?6 u4 m/ T# F
      echo '<div class="wrap">+ o8 [5 p1 W/ T
          <h2>全站公告</h2>
. a5 ?9 x8 B/ G5 i% i! B          <form method="post" action="">+ u1 t4 F4 E4 c2 l
              <label for="title">公告标题:</label>
0 S1 q+ k; T/ q$ q8 ]. Z4 M              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>
- Z8 w& }& N# e/ O6 z0 i* U; I              <label for="content">公告内容:</label>
; F9 B6 p2 N% ?; X& V              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>" S6 }0 D( X4 x6 v$ C: e5 [
              <input type="submit" name="submit" value="保存设置">2 Z3 k+ N+ e- ~& W2 R5 c
          </form>. H; G$ T& `. v  H! n2 U
      </div>';, v  o2 ~; K2 c5 C' V
- A' D0 l8 C  V. e% K, S
      // 处理表单数据( J) Y! h* p! g7 {7 Z: E1 [
      if (isset($_POST['submit'])) {2 f' W, \4 b6 y. z: v
          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));
" N5 V/ U- Y9 M5 O* @          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));/ l* O/ \4 O1 t2 O' N
      }0 k0 s! Q5 o3 _2 J2 \' V6 L8 o9 @
   }0 d& n5 n) c) s, D! c
   ```, C% Q1 }" I: e& t/ M6 H

) D7 Y( T5 r; \   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。
' a) @) H! q+ j* a9 S. J" C+ k) \) H5 Y8 N% ^% m
3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:  U( r0 s# v( q$ X+ L8 t

9 Y! Y% ~4 h1 S( i1 z# K   ```
2 q4 i* _; R1 T5 P) b" N5 M0 r   <?php  ~3 M7 W% z8 D# {
   $site_wide_notice_title = get_option('site_wide_notice_title');
; C3 ?$ [0 `" D2 i   $site_wide_notice_content = get_option('site_wide_notice_content');
( T1 ]! |$ |$ ^) T: \   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {: L- U- w6 q; a7 J5 m7 u( \' |( o/ f
       echo '<div class="site-wide-notice">';
; B/ @# E( A& Z6 i% ?, d; V       if (!empty($site_wide_notice_title)) {
, m+ w3 ?; l; x7 I" }" \           echo '<h3>'.$site_wide_notice_title.'</h3>';
% S8 {( y* u+ x- G8 e       }
7 @0 C( B- _, x% i* p; E# [3 R       if (!empty($site_wide_notice_content)) {
( {4 J, z; B1 s( I) [; ~  g# Q, Z           echo '<p>'.$site_wide_notice_content.'</p>';) a& Z, ]- F/ a# m4 I
       }
; }, c& w2 D* k0 d" Y1 l       echo '</div>';. z7 J& Z' U8 D! w
   }
; z1 |, {, q1 _- b5 @6 O* f, ^   ?>7 n: m/ |  k- P6 n0 v  }
   ```
+ c6 R+ N6 J& S1 F# O6 h# S( _- z: y- H4 _
   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。: ~) `. F9 }/ v+ @3 \# l5 j

: m6 w0 R3 b* h* `/ K; a5 K, v$ R请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

320

主题

485

回帖

3140

积分

管理员

积分
3140
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?
2 c2 r- f. U/ X% [, m1 |
5 |& F% x) X; c' N, k: q6 s$ z9 y0 X您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:
* v( T5 ]6 T5 s+ j, K6 A
3 e+ b: @' \! y1 `# Z1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:
  O' x/ `5 v/ L; r
, }6 I  S4 z: f```$ P% `$ R. d0 s4 U4 `/ o
function create_custom_post_type() {
! Z# h' o6 s  d$ U) _    $args = array(
$ v/ @: Z4 s* r# t. J" K  [' r        'labels' => array(- L" k+ u! b2 ~7 I: v, P
            'name' => '公告',
9 Q6 V" b+ p5 V% D, B8 n            'singular_name' => '公告'
" j: D: ?1 S5 x        ),7 U8 Z$ N: }" X9 \0 F3 }- J" n
        'public' => true,
& J5 J# s5 ~4 d# Z/ d        'has_archive' => true,8 c: \7 a1 [! W: o1 z0 w0 j! {
        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
9 U2 s; O9 d. n% m7 E6 H2 K        'taxonomies' => array('category', 'post_tag'),
3 w- l% [: g2 q6 |6 p2 k8 y        'menu_icon' => 'dashicons-megaphone',8 _6 e% F$ Z# N; |- ?5 ^7 R
        'menu_position' => 5,9 `  S; P9 ]& ~( c0 {7 S* u% Z
        'rewrite' => array('slug' => 'site-wide-notices')
4 N/ \) |6 v8 Y3 v& E1 g0 `    );
0 R, v" Y; F( a) w. C    register_post_type('site-wide-notices', $args);$ P/ i" [. L9 G% @* ~3 M* s' _7 j+ V
}
( a2 J! a/ Y, C+ @1 qadd_action('init', 'create_custom_post_type');
- ?$ L5 n4 D' w* X- P6 O```
  B# r3 U9 Y* O& {* j' |
. e3 _: y/ ^0 z% E) r* G8 f  ~$ P在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。
/ K8 z( B  n( ~0 k# C# f2 X) q" U3 ~) o: E1 b+ Y. u8 |  }" M
2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。
6 h7 V+ w" X# |" [5 [
0 w& \+ P/ n; S: q3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:8 j; w0 h9 t. m- X

/ W& {0 w  c) U3 o% y9 i2 Q```
: d6 Y0 z$ F# k3 i$ U% J: N$args = array(
, f6 s  w- Z0 q- u! E    'posts_per_page' => 3, // 显示的公告数量' x: e5 p  r. i9 `
    'post_type' => 'site-wide-notices', // 公告文章类型
* T, Q+ u9 [; Z+ H1 a! K) J    'post_status' => 'publish', // 公告状态
9 J9 ^0 L- R6 B/ F% g' b    'order' => 'DESC' // 排序方式# N( ?: i1 `$ U1 O3 q
);
$ U' P6 X" v  E: D6 E0 C  i
' a% x! h1 Q* o! ~; u* @$notices = new WP_Query($args);" I; y% g& j& C- x/ Q
if ($notices->have_posts()) :
, Q. N' t: T5 S" {: c& t    while ($notices->have_posts()) : $notices->the_post(); ?>
" f( R( Z7 B8 o# Z2 [) K: K        <div class="notice">8 `6 Z# H3 r: R2 V. @' H( y
            <h3><?php the_title(); ?></h3>7 ?: z7 n4 ^# m0 r8 v2 V/ g
            <div class="notice-content"><?php the_content(); ?></div>
+ p( S2 g5 r% U7 V) _        </div>7 x  P: ]" G; z+ c2 o7 f
    <?php endwhile;6 ^1 @0 b8 M- y" O8 U) ~/ _
else :
& y. ~. F* Y& o1 u' |7 b- U    echo "暂无公告";
( I" J. b; O! Q9 c( G( dendif;9 ^9 m) S2 A5 t: h$ _9 r
wp_reset_query();
) ]( R8 D7 e4 b```/ m" ?# Z) d( E! H4 s6 S
( q; K) r. q, {1 O/ @9 J6 w
这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。2 u( T: p9 x3 I: E9 g

6 S# x1 |% ~4 J以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

320

主题

485

回帖

3140

积分

管理员

积分
3140
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?
3 Z, l6 s! @' R6 o, t  `4 Z# z& ~9 G9 L0 A7 L* @+ N, o/ h
如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。8 h" X. ~" K5 B
# b/ c0 e) p/ p4 P2 @
以下是创建自定义插件的步骤:
! l9 A7 L* ?% B2 \! t2 r4 K' ~
0 z( n/ s9 l! C- {' B* W8 j1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:, c% v' D* B2 L; B0 ?: o( I  l

2 ?0 h3 b4 _+ |7 j   ```- P# K! y& L3 ?2 b5 T
   <?php
, i; w1 S/ s9 P# \7 W/ w" }: v. g: w   /*7 U, R6 U$ a0 V& t/ q* c( n7 n  ?5 R- h
   Plugin Name: Site Wide Notices Plugin+ t- O% L+ D4 a5 L3 A9 u6 J
   Description: Adds a new custom post type for site-wide notices.
' {; W( _0 o( A& Z& q/ N   Version: 1.0
1 S) W  X/ j( ~   Author: Your Name
6 X9 k8 R6 p2 p% m! n/ r   Author URI: http://example.com8 v: a$ ^# V3 |& {2 S3 ^, u
   */
( ^/ `. h, ?" [* Y7 f
7 k( L7 B1 a5 n  H. w5 n* t   // Add plugin code here...
. ^' D1 P0 o" Y5 s   ```
$ C9 _8 s, Y' T3 M) R9 x! u$ g
7 q: ], _8 d3 F# q, T& S/ w   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。
' h9 M: N7 R/ {. N/ F9 q, a1 e* F
. @/ u2 V: J0 _2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:
/ M6 d7 i* z( Z& o0 j& R; |5 o# a  s3 y2 I
   ```- [8 H* @9 c) C
   add_action('init', 'create_custom_post_type');
% h4 B8 z  }" j% G3 d5 b   function create_custom_post_type() {
! u8 E' p( @/ O0 U+ Z5 Z      $labels = array(0 K- N. y/ |$ J7 k5 E, c
          'name' => 'Site Wide Notices',
/ P" ~; h6 |6 ~9 n; L6 x, R- `          'singular_name' => 'Site Wide Notice',
" V( }& d+ e+ b) N          'add_new' => 'Add New',' _, R& [$ o  u% |6 @
          'add_new_item' => 'Add New Site Wide Notice',
2 G( F; u7 X- J' s6 x          'edit_item' => 'Edit Site Wide Notice',( T/ V0 l& o2 M$ ?
          'new_item' => 'New Site Wide Notice',. u- V2 G* W6 ]: U7 t3 H8 o; O
          'view_item' => 'View Site Wide Notice',
) M( e1 k' M+ ~0 Y          'search_items' => 'Search Site Wide Notices',
4 t/ f2 y- k9 S' }- C1 o& _          'not_found' => 'No site-wide notices found',
: r5 m# G: Q" u" \  x  p; g2 y4 `          'not_found_in_trash' => 'No site-wide notices found in trash'
2 ~( ]6 S/ q" c      );0 _  ~) M+ F7 w) z

' O" p4 L0 B( n      $args = array(
, y" c) A( T9 K% a! g+ y4 m" L  `          'labels' => $labels,
! ?5 V$ m7 P8 D! L+ }          'public' => true,
) b! ]2 K6 s% {; s! R2 C- h          'has_archive' => true,- {8 Z+ L0 G/ Z7 W: ]2 D
          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
3 n# N0 T! Y6 y# d/ S- x6 y          'taxonomies' => array('category', 'post_tag'),
$ d8 q5 F( j3 ]4 u" w6 m          'menu_icon' => 'dashicons-megaphone',: t8 `9 `, T# h" C
          'menu_position' => 5,
$ g: ^2 z2 {; q$ c$ F          'rewrite' => array('slug' => 'site-wide-notices')) K) W, N4 X2 X
      );
' Z0 r) H: }# b7 K1 Y+ v; c
* c% |/ D% X6 B# v3 |6 \      register_post_type('site-wide-notices', $args);0 h* A9 @5 m/ a
   }
% O& T" C2 j( Q& W3 p5 |1 `   ```
+ u2 u" _9 r! R- ^$ z. x( \* \% z3 |7 d4 B. V( j: I
   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。0 ?/ j) _7 z& b6 n; z

9 `/ p& J- `* q6 L$ k$ x3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:
; W5 l9 {) {8 I; ^
: F$ H& T8 ~+ u   ```
  e" J+ I0 e0 {, l   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');
6 o7 l' [! p; q/ H* D; l   function add_site_wide_notices_boxes() {
1 o# }$ T# V3 P9 m      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');
' x$ y# c$ d0 R5 o   }
6 @8 I$ P' S' r' \
* l! h4 v, g9 ?1 l! T   function notice_details_meta_box($post) {7 m: y$ p  v5 k8 V1 a: X! a* d
      wp_nonce_field(basename(__FILE__), 'notices_nonce');
: b: T; e$ ]% c5 r5 ?      $notice_title = get_post_meta($post->ID, 'notice_title', true);
0 P2 d/ j) Z7 W4 A& d3 p, l      $notice_content = get_post_meta($post->ID, 'notice_content', true);
2 D1 T7 z5 Y1 E% U7 W$ i6 X: c      ?># z- _6 `5 V; z0 {6 t4 E- _
      <p>/ H+ a) C: L  B# T( f, X1 A
          <label for="notice-title">Notice Title</label><br>
% R3 h# M$ Z9 z% B. H1 h) U          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">
- f: m4 Y# `6 c: z5 Z' _$ t      </p>
8 _3 \/ n+ T' D. D      <p>
% D2 f4 M. u$ X' A1 t) H9 f3 n          <label for="notice-content">Notice Content</label><br>
% f' D5 g! A  c+ U% n          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>$ g3 _9 ^7 _  s
      </p>5 U, {' N% n# _; [4 q; V
      <?php6 C, }4 M- Q7 a% Q! J& `  |
   }$ U+ x6 f* G4 f2 c) J
0 V1 q9 e6 l# h0 m
   add_action('save_post', 'save_site_wide_notice_meta_box');
- g' ~) y; a( y' {  i6 @   function save_site_wide_notice_meta_box($post_id) {
: e& o& E2 U7 u1 X4 ?      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))- T$ ^5 E; X4 P1 ^: N
         return;: n" w0 Y3 p1 ~* f
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)
) t$ f* Y, h/ G) N6 S% i7 R% L         return;, a% U5 F& G) O2 e. q$ N) w

- b' z" s7 K4 I  F      if (isset($_POST['notice_title'])) {
1 E- x" ]$ m8 Z; V1 g+ d          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));/ F  z" j9 |1 k) t! _' d
      }6 U$ j6 [- ]& R
      if (isset($_POST['notice_content'])) {
7 ~4 i1 e* P; }- D  R          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));) H8 f5 C2 c, S( B  r0 D
      }* D. X8 v* q/ i  V  v
   }* o% k! K' e9 ]
   ```
% N5 Q- j( s3 ?# Q5 `  a8 N) p! `- n& w! z6 p
   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。
" d6 b0 G" Z9 _- V# h5 L! K% N( O0 `5 n0 _0 r7 @1 X) [3 c
4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:  ~: w! ?4 ~+ w. O3 |! `

5 S7 |4 P6 S0 D. Y" b   ```
& q- `$ V6 @: a) L6 p   $args = array(7 E( |: w  k7 g- i
      'post_type' => 'site-wide-notices',% b( L% x: _  P; I& c  y. B% P
      'posts_per_page' => 3,1 r  M7 M5 Z% \( {" Z8 {
      'order' => 'DESC',. r1 j. Y" G1 R/ Q/ B0 p
      'orderby' => 'date'1 I. }' ~+ j1 `7 w
   );, u% o1 G3 K+ M8 Q% [1 B) v9 T6 L
   $query = new WP_Query($args);
4 f8 ~8 i0 y* D: B   if ($query->have_posts()) :. a2 ~2 j6 H* ?9 y
      while ($query->have_posts()) : $query->the_post(); ?>; U& }- S) f/ D: i3 G
          <div class="notice">
7 N: m0 l. t: b$ ^              <h3><?php the_title(); ?></h3>
! s9 U. y( i: ~9 z: C* \0 b2 e; P              <div class="notice-content"><?php the_content(); ?></div>: M* K- o' u4 y- T7 h' i% _2 l
          </div>( Z4 f3 w9 x5 R5 b' y9 T6 b
      <?php endwhile;2 v, G! D6 L# ~
      wp_reset_postdata();$ p% p+ V4 h5 m3 C+ c: E  g- N/ `
   endif;: o& x. [3 B& y; d6 A1 c5 H/ r: z3 C# T
   ```
! ?3 @3 ]' E; F' _) }4 |# H  [+ I7 e( X
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

QQ|Archiver|手机版|小黑屋|通达产控投资 ( 粤ICP备2023021749号-1|粤公网安备 44030402006137号 )

GMT+8, 2025-8-19 14:00 , Processed in 0.091027 second(s), 3 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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