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

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

[复制链接]

331

主题

511

回帖

3351

积分

管理员

积分
3351
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:4 ^8 Q6 O7 T( P- Q
( V2 d& t& U: e, w: |1 K' S
1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。7 j  I/ J3 h+ ]% J

& z+ q2 T  ^; t* m4 ]2 d2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。
7 U1 L0 q: f5 R" c% _1 G
) h. s$ p) H* c( g3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。; h. j7 x, Y7 G3 T) D. g7 X

/ L+ [3 Z: L" q! M8 e, u4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。
+ A$ {: ^3 b( o3 I& t
/ B! N6 w0 }) [) N2 U注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

331

主题

511

回帖

3351

积分

管理员

积分
3351
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?( a. F) u# q; V: U( J0 y. X* K! w

  [7 x8 x7 \& E2 C3 t) @1 k4 r- k如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
" J0 i8 X4 v' G1 p! k& M( P
" I" O9 g3 O$ M2 e1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:8 w: i. t& ^/ Z
9 s2 j' c& p- s
   ```
7 T' X. d. U+ `, e   add_menu_page(' A$ f+ {- f; b" X' A! G  {/ ~
       '全站公告',
% a6 b$ f2 i* A0 f       '全站公告',& M9 [" @, Z. @  U4 i9 K7 T
       'manage_options', //需要的用户权限
9 z; I1 S# c5 f. e$ v8 f       'site-wide-notice', //后台页面的 slug9 ?: [. [9 W! j* W, M+ J
       'render_site_wide_notice_page', //用于渲染后台页面内容的函数& V1 G3 H- P( |) m
       'dashicons-megaphone', //用于显示在菜单中的图标2 q4 p+ Y# t+ s4 C0 y. x" v' \
       30 //菜单项的位置
" c; H6 E9 [. t3 \: \% {   );
. d1 d& y( g' M$ N% u# `   ```9 ?6 i: N: W. n$ T

3 ~$ l& p! d' _3 Q, m   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。
0 B' P5 n4 I! ?; G5 `" q, F3 L/ G' F. b. h; E$ Z
2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:7 |: R! w! h8 g% [7 t

/ H* r7 _1 R9 Z% i5 Y   ```
0 i0 A2 v7 d+ O$ [   function render_site_wide_notice_page() {
4 v/ R7 @& B* J  [      // 渲染后台页面内容
& j- e& d3 B' G1 ~( _      echo '<div class="wrap">
8 A6 C! W/ m0 h$ V, Y/ r          <h2>全站公告</h2>0 c6 O$ u. W  A$ F
          <form method="post" action="">
8 r1 b$ }2 i' O: t; z# |$ o# \, \              <label for="title">公告标题:</label>; A* L9 f' g( P  L  s
              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>% W  Q8 C- [6 x
              <label for="content">公告内容:</label>
# E6 Q9 ]" t$ u% F7 q              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>
; U4 O- n$ q* C, e              <input type="submit" name="submit" value="保存设置">( T% w: [! \  H+ l/ z7 @" y
          </form>
$ T6 j7 s# w+ U" E      </div>';
, z; |3 d2 [6 m  K# l1 Z( }: x- m! M' p0 L5 i) K
      // 处理表单数据6 [$ G7 J  [3 T/ J3 R
      if (isset($_POST['submit'])) {
% Y7 ~) |6 S! x: V' K' j- m; c          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));
) T" X1 q7 N8 y1 j- l1 [          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));
8 m) j- D7 U  u+ p) ~; G      }
* K% p2 o& X1 q' K1 _   }" ?0 R5 N" b8 K1 j0 L$ h# t: g; r
   ```
. v/ e& T( M& d4 M- q8 E  ^
0 g; d* e. |$ |* j5 M# ~   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。
; d. W5 x6 n& W% [+ n2 X
* o3 a0 s: w+ h3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:  r+ p: f- |/ T/ G% ]6 X( a/ t4 Z
# G1 V2 H5 W# b3 J# u; @/ t# Y& r8 k& T
   ```. @$ q& H: m( |8 D' q0 B8 Q
   <?php
& N6 s; c& a. P4 S. d# ^$ q   $site_wide_notice_title = get_option('site_wide_notice_title');1 g2 V$ Q; [/ y5 G5 H
   $site_wide_notice_content = get_option('site_wide_notice_content');
9 U. q* c: U5 q% |; h6 w   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {+ X" G& \5 l+ k: a& g
       echo '<div class="site-wide-notice">';1 M( @' \3 Z! C( A5 ], C4 z
       if (!empty($site_wide_notice_title)) {
4 m0 D/ A+ a/ U; o3 T0 Z           echo '<h3>'.$site_wide_notice_title.'</h3>';2 Y4 j/ Q: Q% D4 L
       }. S+ }7 i. D, W- [+ i
       if (!empty($site_wide_notice_content)) {1 c1 ^3 f5 K7 A& l/ }
           echo '<p>'.$site_wide_notice_content.'</p>';+ `5 A" r  x. f( N
       }5 t9 x2 [* H6 f2 I0 y, u1 C* s( y
       echo '</div>';
/ n9 h9 U2 W3 g& j) j   }
+ j. z+ I( p& l$ D* @3 c7 b   ?>* {1 d' q5 Y; o' c+ @, y; U, N
   ```
3 B" }1 c+ o! |' U. L; f
2 T* P1 e9 x8 G. `) f; k   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。- {! z( W$ G) Z: T9 J6 i

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

使用道具 举报

331

主题

511

回帖

3351

积分

管理员

积分
3351
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?
; w8 j) w- @+ s  V. |% @' D1 m1 V0 X2 I3 X0 B! N" X+ w/ F" H
您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:- Z+ _+ @4 a7 X, w3 m3 h
$ X6 S; ^$ O% n( W0 [! D& _
1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:+ I, P$ L# X1 O) Q  k

  M3 k. W# f. Y4 f6 x# S```# O2 w+ W0 ~$ f& [; w6 h
function create_custom_post_type() {
8 M* O& D9 ^8 d7 E/ W    $args = array(3 {  e  X# t7 v4 w
        'labels' => array(
1 q" L9 B1 E. a. r            'name' => '公告',
! w- T5 d7 N0 v' u: l            'singular_name' => '公告'- q! T9 ]  J/ {3 }4 t0 Y, o- M& `
        ),
, L' w$ a7 a: i  s        'public' => true,
8 b7 X3 z; M, `( M; g        'has_archive' => true,
4 E7 M; c  ?' y& F' O        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),3 {; \. w) P" Z; k; l. O; p5 J
        'taxonomies' => array('category', 'post_tag'),
/ j1 D+ q7 S  w* m+ Q        'menu_icon' => 'dashicons-megaphone',
0 X/ k: g9 j( {. L, o( `        'menu_position' => 5,8 d' c' B! ?" }. [# J* B6 @7 ?- x7 F
        'rewrite' => array('slug' => 'site-wide-notices')
. ^" @! R' e0 L. l; }% S# P- y    );5 \7 r, g& F! m: |+ L( U& `: u
    register_post_type('site-wide-notices', $args);
0 ^- D4 {- n8 G: }2 S, Y$ w- N# {6 `}
3 H0 f9 k7 ^; \% Vadd_action('init', 'create_custom_post_type');2 ?  p8 Q& S& t; R
```
" y2 i0 V2 P: M! f: J% P: Q; [' v) y
在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。& Z5 ~/ Q: d* W6 u
. B# ]. q& C/ m6 L
2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。
2 }( E) F, t4 s) ^) Z+ Z, N: o; Q; E1 e; o1 q1 R6 D9 e
3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:
9 }- t4 o" V1 q' k; o& w3 g* U) o. C' g6 k- s& J" x  M8 H
```
( |, \1 {" ?! H% L$args = array() H, [( S* ]7 U4 r& c
    'posts_per_page' => 3, // 显示的公告数量
1 h0 E. o  ~! Q, G; u5 }( f% H    'post_type' => 'site-wide-notices', // 公告文章类型. i% m, n% G* b/ \. j
    'post_status' => 'publish', // 公告状态" L5 R6 v$ E) e3 _  M( N
    'order' => 'DESC' // 排序方式/ Q3 g; }: A1 L7 s: ~% @# ?$ @4 J; I; E
);
. o, l4 M6 ]' v$ D! q. E0 k
# n- f- k4 \2 D( `* B2 k$notices = new WP_Query($args);
- c& N- o. c  o, U1 Yif ($notices->have_posts()) :
/ l0 L6 k9 X- x5 d6 R5 d6 N- l# p    while ($notices->have_posts()) : $notices->the_post(); ?>
! ^1 i. V4 r) E        <div class="notice">
2 i8 L- E  O% E+ b4 T% m2 E" o; l! k9 h            <h3><?php the_title(); ?></h3>
& Z3 T; L6 e7 T4 t0 ~            <div class="notice-content"><?php the_content(); ?></div>, v! Q) c" s% y& ]6 H$ i4 v
        </div>" T+ H3 e' |" T( [5 m2 I1 Z
    <?php endwhile;" U* h$ P) x- O! l& @% A/ |
else :
  j; d' e/ a5 l1 n4 O    echo "暂无公告";
% Z. M% z6 h8 \3 Z, xendif;4 Q( Q, |& k" b/ e; j+ T
wp_reset_query();
" B2 G2 j3 `' @! E```/ I  H8 R, ^4 o1 h& N$ ~, W
- c; s9 c7 |- ]0 W# t* ?
这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。  V( E% |) J2 m  c
9 \, R& t2 A) d6 L% J
以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

331

主题

511

回帖

3351

积分

管理员

积分
3351
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?
! u" L. l* c0 C7 o2 @
0 A+ i6 w7 X1 K! L6 E& F' ~8 l; A0 l如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。
7 ^: ^/ b% Q$ }' L5 I; T3 l0 N' {6 n1 [, S1 q
以下是创建自定义插件的步骤:
. o: \5 f$ w! ^2 ]1 i
( G( K5 P. q# e2 Q  M1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:! l' f; G/ h$ h- q1 c

, Q! J% V& Y! v& e6 a0 U   ```# ]: r1 d4 @; i
   <?php
& S; P. l, y' w: f   /*
0 i0 n& l( ~4 P( S   Plugin Name: Site Wide Notices Plugin
3 L' ]" d( S7 M' N0 C   Description: Adds a new custom post type for site-wide notices.7 H8 Z7 H4 l) t) p9 r5 G7 i
   Version: 1.0
( |, J2 F+ S' O7 E7 x   Author: Your Name
" L- O( A! ]  q6 I. K+ t   Author URI: http://example.com
$ ]5 W" O$ ?8 s   */
% ~' j1 K6 J# e6 L8 r% a1 \0 w* J7 ]/ X" B3 p+ R
   // Add plugin code here...
) b2 r4 C) q# j; h: F" K   ```
/ ^9 }" O1 I2 X9 I
- d7 E. |5 H4 M! t& A   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。
1 l3 i6 a- S& ~. `
, `2 D) M+ m3 k2 Z- F& ^, T, R0 L+ Z2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:
: J/ m8 }5 R9 F
' m; j- s& A/ u: A6 ]. F   ```
" l- ^/ m' a) g/ }  i   add_action('init', 'create_custom_post_type');- `* x. t: k, k$ F# B
   function create_custom_post_type() {! ?& d# U1 E$ g, |
      $labels = array(4 m" d3 o/ q- K4 E# u  D
          'name' => 'Site Wide Notices',
& ~4 v+ Y: k0 j% K6 y0 S0 @          'singular_name' => 'Site Wide Notice',0 }( g$ ]1 m( c$ ?/ C
          'add_new' => 'Add New',! p: L( Y& z* ?6 [
          'add_new_item' => 'Add New Site Wide Notice',/ g! C+ N  c% a. W5 [
          'edit_item' => 'Edit Site Wide Notice',; U0 Z# j1 [# Z7 g2 ~# C( x
          'new_item' => 'New Site Wide Notice',
% j. S9 P' q6 k: Q          'view_item' => 'View Site Wide Notice',
6 b( S* t9 X/ S' f, t          'search_items' => 'Search Site Wide Notices',
2 [) e/ s' u  _( l( G$ c          'not_found' => 'No site-wide notices found',
# H+ X! H& _6 h3 r, Q  p+ T          'not_found_in_trash' => 'No site-wide notices found in trash'
, k) C7 i+ t; U) n/ @      );
2 R2 c; L1 e! b# |' N: M2 J  _8 Q) p6 q  U
      $args = array(
+ c. e" K' i( O3 A% R          'labels' => $labels,4 n7 e; U) c8 r. W% ~
          'public' => true,
: d6 Z0 y  N- ^          'has_archive' => true,
$ Q% N& M7 `* `1 W  c          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),4 f. K+ m6 \& K, \
          'taxonomies' => array('category', 'post_tag'),
& l+ G0 y& V/ [% E! m* l6 ~( O          'menu_icon' => 'dashicons-megaphone',* v- @4 `/ c$ q' B, p( ~
          'menu_position' => 5,
# F9 s! `" q; C) q, f) r" m! @" y1 G          'rewrite' => array('slug' => 'site-wide-notices')' {9 u5 C& y" l8 @( X$ n8 o
      );; N, v+ t- x, L/ u) q# X: l; \
" o5 k  v  L' r2 i9 C+ f+ T) F
      register_post_type('site-wide-notices', $args);/ ~4 [3 E. j+ H0 }, j! f( k1 e
   }; L* ^. c. Y0 ~( D; ^& }
   ```/ U3 J+ v& S6 N' c0 f7 P; {- U0 t" [
& C" q6 O% d- T9 c& Z. [
   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。
1 n; M# h& v, d% y+ c) E, g; L$ E  t+ M3 L4 x
3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:
+ s3 `7 k+ Y5 d/ N- x7 z8 q
* V2 n6 G' h. W   ```& r% i; N- s% t% Y" z
   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');  G9 L0 c( m& y  B4 W' V- Q
   function add_site_wide_notices_boxes() {
9 S  S; c" S7 l& k      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');
  f3 c; q' q( z1 o- }0 P' a; D* ~   }" I$ y2 q8 I; M! B3 ]5 w

- F, z3 @# G+ @) |   function notice_details_meta_box($post) {
9 P$ S# Z: u, {6 p) w; H9 L      wp_nonce_field(basename(__FILE__), 'notices_nonce');1 \0 _3 A4 @" m' F; W3 ]9 x( c$ V% B
      $notice_title = get_post_meta($post->ID, 'notice_title', true);
: \- d$ o8 }$ A# i7 W      $notice_content = get_post_meta($post->ID, 'notice_content', true);
& u# U; u& |! l1 g      ?>
% [& J9 X3 T" `: G% N) C      <p>
& a! E. i2 {9 W  S0 z          <label for="notice-title">Notice Title</label><br>6 G' i# H1 v" r" b, V3 Z
          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">
1 \! v9 ?- X5 Z5 Q' H      </p>
9 l+ ?8 q" Z8 }      <p>
0 [4 {3 V4 o- ?, Q6 g          <label for="notice-content">Notice Content</label><br>- I3 ]  c8 \& I+ x
          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>, l1 K; j9 V. ?( o; t
      </p>
) F4 ~+ u; ~8 _1 z      <?php: o  P) g/ l/ ?* t9 S" R* \
   }7 C" V" q, B+ K' M" P$ i0 H

4 ^4 ^  u0 e# ^, Q   add_action('save_post', 'save_site_wide_notice_meta_box');) l2 g7 L9 w% b
   function save_site_wide_notice_meta_box($post_id) {
: K$ o" Y/ C- g% d1 K      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__))). d6 c, @  z& W& i" d8 n
         return;
1 N2 r: u0 e2 `7 F3 Q      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE); \+ G2 k  x0 R" C* M7 s
         return;
$ C  E6 S5 l8 @* |; Y5 |3 M8 X: X1 Y( x
& V* A7 f8 ?1 I; O      if (isset($_POST['notice_title'])) {
( _, I% L5 ^4 S) h# M* i: L1 y; {          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));
2 j  f2 L/ c1 V& }6 z+ F0 X      }3 h5 O" h1 ]: o6 l
      if (isset($_POST['notice_content'])) {
4 ?, Z' F  R% P0 U2 O4 D% \( V, C          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));
- {7 A! D/ o, W: K) s' E      }, d2 t6 M1 E8 ~( c' }5 V: E  b
   }& z! a# T& n0 B; `" X0 w4 G3 D  W
   ```
% [3 q% d  b( @7 `! w$ K
/ U0 E/ d2 Q1 A2 d   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。
0 y3 ]' T' w' a
9 K0 z5 k; k0 c; I4 ]4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:
) T8 i. U6 h; i" t9 \+ I% x0 d
/ @7 H: H6 H/ k3 \5 e   ```  E0 K; W) Q7 \1 s9 B
   $args = array(
  D$ b5 B+ o& K) g2 J$ N      'post_type' => 'site-wide-notices',
9 R/ @9 G- |) p- G& P1 q) `/ u% O1 n      'posts_per_page' => 3,% l: N! l7 V$ _  w" G* y
      'order' => 'DESC',  n. J: @) n# j
      'orderby' => 'date'
3 D8 N- B" d4 `; W1 {   );" T1 `6 O! N9 k* J$ I- j& i
   $query = new WP_Query($args);
* ~% g0 s9 D5 O! m# P& \   if ($query->have_posts()) :
) _' }. j/ a; u3 y      while ($query->have_posts()) : $query->the_post(); ?>
0 k* Z0 H  b0 T& x- U* ~" J          <div class="notice">! ]% r+ R0 }* D5 s3 B! T
              <h3><?php the_title(); ?></h3>
; ?9 [5 s* a# z2 A4 k              <div class="notice-content"><?php the_content(); ?></div>
6 U0 c5 f! ]9 ^: O0 I( U/ R          </div>8 q) \: i; X' s# ~; z8 k5 P, g
      <?php endwhile;
' M  x2 m! X+ S      wp_reset_postdata();
# O. [4 a* j# z8 l! a! S   endif;$ H* l0 T5 E% U( X4 c
   ```
$ l4 s9 x3 V) s- l$ W6 |# Q2 U5 t& A
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-11-18 17:13 , Processed in 0.070120 second(s), 3 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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