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

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

[复制链接]

334

主题

517

回帖

3396

积分

管理员

积分
3396
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:
6 D- h( i  n) }) S& |& n% V
( z* F: \' c" s$ K6 [9 @1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。
  h* V* e/ u  A( g0 J
/ O! r0 M; V$ Q% A0 y" }$ e% k2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。
( \1 F- l( W' E% ?1 j7 ~! L
$ O. a+ D( U' l$ I3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。& E+ f; h( _8 `8 J6 ]: H
, J% B5 z+ p5 y: W5 x6 w: E
4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。) U1 \/ e5 p  k5 u
% b$ n6 y! w  K4 a" X
注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

334

主题

517

回帖

3396

积分

管理员

积分
3396
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?! V+ m% j2 _# L4 Y( `

$ K- d5 A3 N5 h, |% U$ _2 M. t如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
0 P5 O$ Z  c# y  k* V+ |. ]! N
2 e9 Q6 ?: Q) @9 u* W1 I" [% a1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:5 `, n) n  b2 i+ U$ a; L9 \
: s; U; q* ]; {" O4 a
   ```
7 T8 b+ b* z- w& m   add_menu_page(3 Q( `: E9 _/ {! Z2 L
       '全站公告',+ d5 D( Q- a) e: q6 E
       '全站公告',, W- U& R9 r% x( h+ k- \8 Q9 r& j
       'manage_options', //需要的用户权限! `- o( j" Q$ d& x9 h3 q
       'site-wide-notice', //后台页面的 slug
/ L+ h) h, C/ @1 U, \3 P       'render_site_wide_notice_page', //用于渲染后台页面内容的函数, m4 I  V5 W$ i* z! a
       'dashicons-megaphone', //用于显示在菜单中的图标
, x6 x3 h' Y: |) J) L6 _       30 //菜单项的位置
: N+ D4 T% o# @% f   );/ E0 E0 P& u+ z
   ```2 F/ c. h2 ~& r4 ?1 C, W5 O
% O1 E4 s. w- R# W4 h8 j
   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。
3 d7 p& f/ P8 V; _1 J
% P6 E4 j3 b- d+ r" `  V" R; n  V2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:! [+ J( a6 o( S+ f
; A3 W! a5 r: s9 h' T
   ```
* H' h* x6 v8 _$ P" S1 ^+ b   function render_site_wide_notice_page() {
0 B- Q% I, ?! V$ Z# S+ M6 B! N      // 渲染后台页面内容
  }9 f( B6 T5 j- H# z! p      echo '<div class="wrap">( o3 Q2 P9 o% l: N0 o* I% F- H, k' Q" T
          <h2>全站公告</h2>" ?. ?, I# `) }: C
          <form method="post" action="">
, V. e# x. n, X' K* p4 ^              <label for="title">公告标题:</label>
$ X* i7 `, }$ A( F) S/ D              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>* A: j8 E& @) g4 x2 x# M1 l1 E
              <label for="content">公告内容:</label>
2 k, l: C$ C6 M: v              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>
' E1 j8 b$ q/ f! L2 o              <input type="submit" name="submit" value="保存设置">
7 N( ^1 C) ]% [  y! q) o* Z& i          </form>
# B. E. I$ C' h! g0 k      </div>';1 l2 h( G7 X( Z/ y( Z+ S

2 ?  n3 R- I7 I, p5 w      // 处理表单数据) \9 |$ Y" `% O! i
      if (isset($_POST['submit'])) {- i$ O7 L3 ~, d& P* u; ]) `4 M2 F
          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));$ \, [3 M( `2 p$ w$ y8 z3 O  t
          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));1 ^6 s% F1 T% z  g* ]
      }' X" V( d2 d, {( c/ _3 U4 t
   }+ `& y) B1 H( |* F% |
   ```
4 K9 ^+ R) \% q- Z/ T( q7 p1 J5 q7 l: X: X! V
   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。) x: t5 d' \6 [# O

+ [' }! c: G3 {: j9 a; D2 Y3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:
) v5 o, m" I: ~" Q4 a+ N( ?+ \1 H5 x2 M
   ```) W3 J9 G, I2 d! u- {, m
   <?php9 p, e! L4 q  _: ^
   $site_wide_notice_title = get_option('site_wide_notice_title');5 ~! V' A% {% w' M* l0 J/ K2 ^
   $site_wide_notice_content = get_option('site_wide_notice_content');
  @6 g; _8 \! {" s5 V   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {, B6 V, w( \" q1 n
       echo '<div class="site-wide-notice">';( H: j* K( `4 I) q# w+ X  O
       if (!empty($site_wide_notice_title)) {
: c- Z% X( x# O2 \. d           echo '<h3>'.$site_wide_notice_title.'</h3>';/ Y  S6 J+ R# J( S& Z/ l
       }
4 m3 t8 U8 C" R+ I" z6 E( s       if (!empty($site_wide_notice_content)) {. o% l# A5 C: Y% d6 s4 ]! {
           echo '<p>'.$site_wide_notice_content.'</p>';: m& o( d7 G- {) F, \3 k6 T# q" y
       }
: k& Q1 \: v. }       echo '</div>';# h8 v: O% W# @" Z/ l
   }/ _0 J2 p( ?% ^
   ?>$ D& J( Q+ ?7 u# \/ H
   ```
" u4 E$ [* C# N0 X5 _( i' `# z- p0 p6 S, ]6 V. i
   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。
: d# o9 Q1 j0 }# [; |
1 b' R/ S  y# @: {: w. i" k, w请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

334

主题

517

回帖

3396

积分

管理员

积分
3396
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?, L. r7 D  f: q
9 C; J% [- B6 e$ f/ p
您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:
3 X" c, j% X. t! f7 a, F# d
: Y6 @' m# w/ P+ [1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:7 m' h, W) t) j* p
/ S1 ?' t5 @  W  c7 {  X$ C3 }  T
```; j' }6 L, p$ [2 r- k: V
function create_custom_post_type() {; p6 O* K( X  b$ v- D7 t
    $args = array(
: W& O  h4 F$ n( k4 x        'labels' => array(
! A- L) |; c2 N/ y            'name' => '公告',# c  F# X' x. [9 {
            'singular_name' => '公告'
! M* S, W/ H( C. `        ),8 B8 w6 v) U- o1 N% a% R, }
        'public' => true,
# ]  ]4 G: [. B, x. f& m* Y( k        'has_archive' => true,
; S3 k, Z5 q1 ~9 t& {" P- C5 M        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
2 T( Z6 `5 N4 q) _3 w, h/ G# N        'taxonomies' => array('category', 'post_tag'),
3 C/ x: O+ h4 V# n# d        'menu_icon' => 'dashicons-megaphone',
# o5 P& Z" m, f4 X) `        'menu_position' => 5,
; i; d6 p) m, Z$ Y        'rewrite' => array('slug' => 'site-wide-notices')
; i% M& V! k  p5 A    );# Y1 J, s& m; j4 M! x2 n, r
    register_post_type('site-wide-notices', $args);3 m6 \& c. a- W: U9 [: ]
}, c& N6 N6 X+ f! o3 [
add_action('init', 'create_custom_post_type');
/ u) ?  {  a8 F+ ^: X3 a/ g( F8 Y* }```7 Q2 V& i- R) |1 K
+ E4 M! ^% |$ L% @
在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。
- l  h, }, b$ K+ v6 D  ~3 n% d+ U$ E3 y5 W( l" K  k) C7 J
2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。
6 j5 m7 e$ ]5 Q( ~1 f# V, \6 L6 E& ?/ Z3 E4 Z) z5 i
3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:
# W/ |8 k' S& C' Y+ b" U
6 T$ U/ v# Q) i3 p2 @$ Z```6 ^+ q3 s4 D2 F: w  U/ I. P* E
$args = array(* j9 \1 u. q% X# K% K& O" E+ I
    'posts_per_page' => 3, // 显示的公告数量+ H! g$ q0 ^0 M  c; p) D- {( t
    'post_type' => 'site-wide-notices', // 公告文章类型
' _( {6 ^( O* u$ q    'post_status' => 'publish', // 公告状态
4 w! f3 D5 T; {, x2 l" c3 x    'order' => 'DESC' // 排序方式
& @% R* R- B6 N1 }: e0 b& Y* E+ g);' X1 _$ i/ s" o5 T
7 m+ K& t1 H) C0 g2 I
$notices = new WP_Query($args);' b, x- i) r  Q$ w2 u
if ($notices->have_posts()) :
8 C' ~0 r) L+ M+ S5 R5 v    while ($notices->have_posts()) : $notices->the_post(); ?>/ X5 d* c+ c, w5 \/ `
        <div class="notice">
' G8 w! T% f2 L; R7 H0 Y            <h3><?php the_title(); ?></h3>
0 ^  P9 h# v# v8 I* ~1 C; J( ^; J            <div class="notice-content"><?php the_content(); ?></div>
) }* v0 Z4 _9 [, R/ B1 z. u% t6 }        </div>& {+ K5 b/ T; E& g7 N' Q& x
    <?php endwhile;
8 g& v% \: M' S' ~2 Y: a* Y1 ~else :' T% J9 ]. O6 f& C9 e
    echo "暂无公告";
: c! d6 P% D4 A& Hendif;
- F7 P! k  ^) D0 f: R8 [* y# H3 G. `; swp_reset_query();
1 t7 v% Y9 ]5 k# F/ Q2 P```8 z# L1 N5 r, L8 u8 Y" P& k
  l$ D" J& o( X5 f4 Q. p+ c( q
这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。
( Q3 L* T) ]+ Y1 k% [
% D# Z# m' O. i以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

334

主题

517

回帖

3396

积分

管理员

积分
3396
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?/ k- @  T' s$ X# H$ x
- P9 P0 @! _6 E7 C  D3 a+ I* Q
如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。# N, z7 W& ^) \1 ]' r2 i

; [+ }5 E  A2 {; x2 J% o9 ^5 v7 z以下是创建自定义插件的步骤:2 w6 j1 L! {, X% l" H) Z
* u' o9 _1 F7 _9 ~: q+ C
1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:; x) V' t" Z7 V9 M
+ \, {. O1 l$ Y2 F7 w1 s2 }6 I
   ```
' d" _4 s5 t& B5 ?$ d   <?php
+ H9 }' y: m0 y* ?9 x4 J   /*
% u% S% Y; [0 U' f: m, l   Plugin Name: Site Wide Notices Plugin& ~" }. k. Y4 ~5 K0 c% e
   Description: Adds a new custom post type for site-wide notices." }0 \) u) H% P% a/ X- O
   Version: 1.0
/ K# B0 @, ^, J- V  C   Author: Your Name2 D1 k0 z  k9 g" J7 g' g
   Author URI: http://example.com
8 j' c8 q1 {, Q5 K" w* B   */
) }2 F/ M2 u0 l! D. f, n4 r0 d- x/ a3 b$ c! S, l# H
   // Add plugin code here...* z5 z0 p% f3 \6 E+ L
   ```, C! G) G2 D4 o) G$ a: b3 E; ?& l3 j

* j, r+ W% `% r. F$ |9 N   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。9 \7 }% [, B- Q. r/ T" f' r
3 T# {6 P4 ?& s& ^2 p
2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:3 U) h% ]* j4 E8 s- `

9 I3 ?- A( n7 y" o) x& x* O1 q   ```
; h' j& J* s" o9 m4 l$ T- \   add_action('init', 'create_custom_post_type');
( u8 |$ u4 H! U; x   function create_custom_post_type() {6 J! ?+ z; y8 n! n
      $labels = array(
' c! z7 M" \# K! m+ G          'name' => 'Site Wide Notices',- A& X* M' P4 n) m- N
          'singular_name' => 'Site Wide Notice',* [' |( u/ }- a( B) \
          'add_new' => 'Add New',7 Q- c* |- S8 |, t' O
          'add_new_item' => 'Add New Site Wide Notice',
2 E& W+ e6 S4 \, J  @6 z7 v          'edit_item' => 'Edit Site Wide Notice',
6 g8 S+ V! y( m8 V8 j          'new_item' => 'New Site Wide Notice',
' f$ n  h4 k9 _+ W          'view_item' => 'View Site Wide Notice'," S1 s5 F* E) {: i- f. D
          'search_items' => 'Search Site Wide Notices',
1 ?: R8 D) m! H  s6 }          'not_found' => 'No site-wide notices found',# k# B4 x6 Y& K, N" Q
          'not_found_in_trash' => 'No site-wide notices found in trash'7 b! {) N9 b) @; w! R: D& s
      );
6 s7 T% M$ _* D: f" H' h
) `8 {8 @1 i% D6 Z) ], x3 A2 \      $args = array(& Y! d  Q  L$ o
          'labels' => $labels,4 f# m. t3 H! e0 u6 K
          'public' => true,7 {2 Z1 {2 r. X  X, P' g, {+ ^
          'has_archive' => true,
4 d$ s% G; C" u0 n) F" H          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
1 Z& f# O, u6 _4 R          'taxonomies' => array('category', 'post_tag'),
3 N# P8 R# j$ o* y) v% C          'menu_icon' => 'dashicons-megaphone',
8 E! E% Q: h' x. I# E' Q% K7 }          'menu_position' => 5,
7 J) J6 s' I  k- j' Y$ }) @' ?          'rewrite' => array('slug' => 'site-wide-notices')
! N, Z, \- g6 P, w) i      );
" f, g: P" B( |4 T  ^
& Z- P/ _/ U6 r3 _      register_post_type('site-wide-notices', $args);
3 y3 r+ r3 y6 t7 e5 h) S   }
5 j' E1 Z, C  Z5 l5 V% R0 ]   ```
# e8 O/ A5 `$ h4 u8 O- t( T' [  c% ]# b
   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。
: m' D4 f) o, I+ Y# y0 Q8 a; J1 t
3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:5 x# o, r' W' b
6 S6 m3 V' d6 m* L8 y
   ```1 U: w" m- u: H5 H7 P- [2 u) K
   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');1 |6 E7 N/ f  V
   function add_site_wide_notices_boxes() {
9 Q' n8 O) L/ T( T, I      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');) _* d" s8 z- p4 P0 Q. R
   }4 K7 I3 r: d( M5 |

- Y8 _: p5 P7 i- |# h9 k   function notice_details_meta_box($post) {
; c" R- |1 r% \      wp_nonce_field(basename(__FILE__), 'notices_nonce');
3 G' a. f$ ?% A% _3 W9 a# Q      $notice_title = get_post_meta($post->ID, 'notice_title', true);1 b' ]& ?, p- _/ s" h0 C! @
      $notice_content = get_post_meta($post->ID, 'notice_content', true);
4 M6 I8 m( f2 G      ?>5 p" s* h' p5 u* i" @( G# S
      <p>
4 y# P0 p0 n  _- q. I- U          <label for="notice-title">Notice Title</label><br>, _; P: U" a; e0 ^/ Z* B
          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">
" L3 J5 R5 J" M4 e, D& X      </p>
7 ]0 ?* K* i) m) p: F& T      <p>
6 A' R; N4 J; }7 M          <label for="notice-content">Notice Content</label><br>4 b; w  \9 q, d8 I9 s2 {& x
          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>
4 {# ]- X; a& t- m      </p>
$ A9 l) Q. o& k7 L- m      <?php
$ ^# M0 c: u8 m. H$ k   }
! \' R7 ]/ p' t7 Q. i4 _- F8 X% f) j! |
   add_action('save_post', 'save_site_wide_notice_meta_box');5 _/ i- _  I. u* a& A( B" ]8 Y& ?8 p+ G
   function save_site_wide_notice_meta_box($post_id) {. C* F) Z1 L. \7 o% v4 Z6 x% `
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))- C: ^) Y+ Q5 r! @6 }
         return;8 j$ H/ N8 y: N3 C9 q+ d
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)
7 l9 Y4 B8 A$ }; N& O) i( Z         return;
9 J1 G6 T# d) F+ J( h: Q1 D
& |" U; J5 z( x+ ]  ~% H6 D      if (isset($_POST['notice_title'])) {6 v1 m, M* i0 l7 J9 E1 z: H
          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));
; Z: f+ Q* ~" Y  N) B      }
2 E8 \% [* E/ ]7 Y      if (isset($_POST['notice_content'])) {
" m# Q  R/ ^% ]3 R- D          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));
: [% O/ R- b8 N$ q( g  ?6 k7 a      }1 n* Y9 w% c' \: i, B! O
   }
+ ~( Z) }2 g2 V7 S' K   ```! {: q- V5 F7 p" I! r) `  ]

6 [" I2 n7 U6 s4 G   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。
4 @2 G: M9 g1 T" j
5 l& ]+ J  j4 E1 o4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:. o- X, l* B! k+ t) Y( K

; i* W; h' ~* y9 K; e$ e; T1 G   ```
# _) _, `* U4 E# ~   $args = array(
6 D! q' t+ j( N' \3 ^      'post_type' => 'site-wide-notices',
/ o% J6 Y; h3 E      'posts_per_page' => 3,
+ H! L  K2 ^& y8 c# W, R+ g; V* w      'order' => 'DESC',' P6 M& k$ A6 K+ k6 N0 D
      'orderby' => 'date'
+ E$ z2 |0 u7 w) l   );3 R' W% x8 ~! Y7 e1 @
   $query = new WP_Query($args);6 f2 N1 {( b7 V* n; W) w3 L
   if ($query->have_posts()) :
! v- Q1 ^$ c2 E0 H/ ?% {" @      while ($query->have_posts()) : $query->the_post(); ?>, [6 r- R& ?6 H. z4 c) a
          <div class="notice">1 b% o" f! n2 O# ^5 d. _4 h
              <h3><?php the_title(); ?></h3>
; ?( t3 c0 \, }) R+ p, A              <div class="notice-content"><?php the_content(); ?></div>
% Z# M1 Y/ K2 Q6 m: C3 E' N  q3 ]          </div>
; a( Z2 D/ _7 H3 {7 r      <?php endwhile;! Y) P4 g6 i) t8 N, I
      wp_reset_postdata();
: V( R9 y* o# K$ b6 L7 q  A0 f   endif;6 c4 }( F* T4 P- @4 y
   ```
* ~* z" a$ o" f5 N5 v/ d# S  P5 a2 _8 ]
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

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

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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