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

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

[复制链接]

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:: M$ e6 N9 F1 q: D

. A, `8 Q# Q9 \9 k- o1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。
3 i1 o* b1 Z' X" `; q' ?9 ~  h* J/ d# ^, V/ |1 U( c
2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。' j' g1 z, t8 B/ B/ \- ~. M
- J% C0 M: U' Z. t, d
3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。
9 b* B3 n" |/ ]2 ~* S0 G1 j$ z8 l% Q0 O2 b6 U/ o
4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。
0 w5 F8 {: Z& G  f4 ?* D0 T6 R; B3 {
注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?
6 k. g/ g1 R8 H4 {4 r" y, K
0 \, k. M' G0 w; u* Z如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
3 ^. h% H$ M; K( n8 O2 |6 }
3 h1 K* r( [/ a  W& d4 ~9 d% ?1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:9 i3 ?4 t! i" o3 a. [
5 A9 @1 ]) H1 ~6 U  r
   ```  k& M- i/ e, W# h. h, r4 w) W
   add_menu_page(! p7 _+ c$ e+ z5 b# y+ u7 i
       '全站公告',
8 j7 C! D2 l( l$ p$ X       '全站公告',
6 s7 {: _# [; M1 A       'manage_options', //需要的用户权限
! Y# u' \0 S: c/ C4 p: P- [       'site-wide-notice', //后台页面的 slug" O( M3 ~5 ]$ B7 H
       'render_site_wide_notice_page', //用于渲染后台页面内容的函数) r! A  O1 V. w1 @
       'dashicons-megaphone', //用于显示在菜单中的图标
& u6 `# i/ q6 `; p       30 //菜单项的位置
5 C, G$ D# {9 k1 S   );
$ A( _" [+ _* a- q$ a8 s3 k0 F   ```
: g7 h  S) K* {( w  m: f
/ E% c2 W& s9 x   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。
$ x  s6 j( t% O  T9 A. T' `- K4 e9 [/ x, ~; P$ {" Y
2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:6 |" r" D6 G8 _
- b1 y. M( M1 Q/ q. s9 h$ C  t+ T
   ```
# z, _" X+ ]' s. I( [   function render_site_wide_notice_page() {0 @1 E: }% H( C! |4 j4 b, M
      // 渲染后台页面内容
( d9 F/ }0 a5 k" j      echo '<div class="wrap">
& ?1 i, a# L; e4 N0 b! m          <h2>全站公告</h2>
5 G+ Q; n. R% L6 z6 R! k          <form method="post" action="">1 q* s8 F( i) F
              <label for="title">公告标题:</label>9 F4 A# B7 s+ C6 @4 ], z
              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>: s. L' v5 J  p2 M
              <label for="content">公告内容:</label>
- a% a8 F8 I* ?2 @2 k              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>* G0 J# x2 s& _1 B. E
              <input type="submit" name="submit" value="保存设置">8 m# E! ~! T/ K/ h5 a2 i
          </form>
1 G  Q" M% K  S- y3 c( T      </div>';
( X) {# G- h  L) J9 Q/ h: c
& C7 p3 F) ?: p      // 处理表单数据
  m/ j9 w3 c! M9 H4 D8 @      if (isset($_POST['submit'])) {
7 V0 m" n6 m  p* l8 C4 s' b+ {6 r          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));5 b8 w4 |6 C. b  u# h& n
          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));
' H1 x! M0 }& w6 B      }
& r& g2 r$ t+ y% S- J3 B( Y% n   }
0 U2 b' [6 o: e% O' T4 z7 v   ```
" E' z2 y) L5 P5 b9 l8 M
: F- S0 }/ z( P, b. R   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。
6 q1 k- X1 e+ U8 s
  a# l8 L. u4 j$ r7 i& `* _3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:
5 F) Q- J# i; m" V( Y/ a$ `; J4 P5 |# U. S
   ```
+ D! |7 V7 c* h1 U3 a1 y1 q   <?php
: w$ h4 u* x. d3 q* i   $site_wide_notice_title = get_option('site_wide_notice_title');
, v: P7 m% A4 i& N( }% o1 ]' n# l   $site_wide_notice_content = get_option('site_wide_notice_content');
& o+ H) S  N/ {9 Y   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {" U+ ^, {% A2 N0 e) U
       echo '<div class="site-wide-notice">';
9 i6 w$ n) a7 e" F: T* e/ k5 p( n2 e: S       if (!empty($site_wide_notice_title)) {
/ W6 n4 I' E$ o$ C$ \; I" [) O1 R           echo '<h3>'.$site_wide_notice_title.'</h3>';
+ P/ \8 e& p, e7 ?       }
; m3 q! {  m8 t       if (!empty($site_wide_notice_content)) {
6 E5 `* F, ~- |' ^3 M/ H  `           echo '<p>'.$site_wide_notice_content.'</p>';2 d6 }' |6 t7 Q; C. H" E
       }- J- j; p& z$ y8 k5 l' L
       echo '</div>';
' H2 D/ P! {( S   }
& V9 _6 D' l# ^; y   ?>* H( q* F0 a0 A8 I# ^
   ```- l, s; i) f2 p3 M- E* U3 B% q

7 F5 x( I* Z) e, w/ W3 T   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。  F6 z8 Z7 Y% i, n
" A2 S/ ?( O) M: w5 b
请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?1 V" x. i0 ^$ n+ A& R4 p

; q& Q& G1 @2 }您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:6 C) V, |' O" x

/ @% o' L8 M( l( `8 c1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:' F& K7 P3 V2 t6 I4 B) C+ b
& P) @/ h3 `! p6 f5 o
```1 Z2 g: |6 j) s' V8 }/ d2 \
function create_custom_post_type() {
5 g# Z# {% o7 m# q7 u2 h    $args = array(
/ E: C9 v, F2 Z& ?" g5 U        'labels' => array(
: V; Y0 K( K0 t            'name' => '公告',
; b5 i* p6 A! `0 y. X$ _            'singular_name' => '公告'
; p+ I- r5 w" Q5 z- q        ),
7 b0 j' Y8 ~: Y5 K: g' v7 G        'public' => true,
1 J' O0 f3 ?6 c+ k2 t/ d& A        'has_archive' => true,, y  r3 }" Y* M0 M2 r! x6 Z: L) E
        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
# v6 }- N6 {9 C, }! `+ a$ }8 E# ^        'taxonomies' => array('category', 'post_tag'),' g. e7 l7 d: H# n6 M
        'menu_icon' => 'dashicons-megaphone',% K5 a$ u" Z0 N6 c
        'menu_position' => 5,
# w$ u" R8 @: f7 C" w2 o; k) l        'rewrite' => array('slug' => 'site-wide-notices'). Y# D2 X; w" E) m, O
    );# {) e" n, v+ W. ^- ]; Y2 {% ^
    register_post_type('site-wide-notices', $args);
. B7 U9 i! D* B3 p/ r* p  v}
; F8 c+ v1 q; o/ c' Qadd_action('init', 'create_custom_post_type');
7 \. }& b+ O" J```- P" X* K9 a' T6 V" e3 Z: m

0 |9 g& G+ k, A, j% l在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。
" E$ O4 B& x% H- ^6 r. d* Z% z
7 \. w/ Y" x& n% v" ?' N5 Y2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。5 Q3 N0 S( B; H1 k+ S+ h- O

' o" _3 N8 b  N0 {' G& O3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:) a4 j0 M; a) `( N4 Z6 ?4 u

8 s6 }- S! U9 j& O" R, y  K9 J```" l. j0 w. A: p, y3 y* k
$args = array(/ G4 E3 ~9 N, z) y# ]; l8 y5 q: M
    'posts_per_page' => 3, // 显示的公告数量4 ~1 \* G7 l/ I2 \( }6 ^
    'post_type' => 'site-wide-notices', // 公告文章类型& |8 o4 I6 n) r. D5 y" j9 Q5 ~6 T
    'post_status' => 'publish', // 公告状态" m8 I, v$ `- d+ h
    'order' => 'DESC' // 排序方式
! E* D; {, B8 r);% d4 \# c" ^2 u; F! i6 |/ n

$ Q# \( {* ~9 t: H$notices = new WP_Query($args);
- \+ W* f( b* h3 Y! ]% Kif ($notices->have_posts()) :
3 T0 M; N0 g/ F  b5 B    while ($notices->have_posts()) : $notices->the_post(); ?># [2 c% B$ f1 a% B0 x8 C2 W7 Z5 N4 V7 p
        <div class="notice">
* g: d3 R( G" O  K            <h3><?php the_title(); ?></h3>
& x0 `+ u0 h: o# S( ~. S- n4 y) z            <div class="notice-content"><?php the_content(); ?></div>; `  w/ d! _/ S% L. i' M
        </div>
7 l7 {: @, b# }3 j    <?php endwhile;
$ H8 {4 V' F5 }7 S0 ?2 U6 h' nelse :
! S% N2 Q8 }" q/ l; Z    echo "暂无公告";
# E* k+ l# D; aendif;9 P' {, y! j( r, Z
wp_reset_query();: o. _7 w' G# Z  w- u$ f; O3 y
```% r, m. K( l2 J/ G

, Y4 `3 U5 _+ D; n! V8 A. ~, z7 B这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。% B5 {, E* [5 _. @% b* I

  }' G2 m0 q3 a! I以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?
$ @1 F$ h+ _' U3 f  f, w( S# a
/ E, @) _! W5 D如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。
: O: w8 a0 P$ g) J2 D, d: B
# q  U1 G6 ?8 K9 o- W以下是创建自定义插件的步骤:: [! a1 Y7 P  _
. s, `; n+ u+ }; T
1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:) q  s0 r! e9 m; [/ B9 W6 t
: B0 _# Y  ]6 U9 H/ f
   ```
9 M# f5 J* Y' ~' ~4 I   <?php7 D# I8 f4 ~& `/ o
   /*& F; c0 ?) X5 z0 n/ G
   Plugin Name: Site Wide Notices Plugin7 |- N" I$ ~' X/ I8 \+ w; C2 P
   Description: Adds a new custom post type for site-wide notices.
1 o" O' n- O4 l8 m' l! f3 h   Version: 1.0
" ~4 j% ~) x- D" w- W   Author: Your Name4 z' {/ F, C9 U
   Author URI: http://example.com, v. x- f# F1 v3 \! \
   */  z5 F; i0 f( T9 C4 w: K+ h
- F; x/ u4 \& J' M3 x' m9 S* l# Y1 x
   // Add plugin code here...! s9 X. Y# z) H) Q
   ```
7 V& G$ r7 S, [# _/ f" q( k' ]" @, r$ y2 k9 K9 b6 I3 M5 R
   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。# j  G9 f, {- {  x2 ^0 N; n
" @- m" m3 Y  w, h$ A1 p; E6 z
2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:
/ ^) e1 v; ?& v. e- ?# n8 \6 Z1 w1 \- P# c3 T% `8 O
   ```
! q; Z+ I. d) l& ?. z$ {3 W   add_action('init', 'create_custom_post_type');
$ H5 [9 K6 p& j+ O0 P   function create_custom_post_type() {; U7 B- K+ `$ v( j/ \; D4 }
      $labels = array(
% C; T1 s3 \/ ?          'name' => 'Site Wide Notices',# A5 k6 R7 O9 C0 r% F
          'singular_name' => 'Site Wide Notice',$ r$ u) ?3 _1 M: P' F
          'add_new' => 'Add New',( u/ t$ k# H8 C. t6 h. Q6 {2 r
          'add_new_item' => 'Add New Site Wide Notice',' D3 [% m/ K: d- y8 U
          'edit_item' => 'Edit Site Wide Notice',9 Y* ~  S7 y# x  Q. G9 e0 K
          'new_item' => 'New Site Wide Notice',/ P0 I' Z  F+ k& Q
          'view_item' => 'View Site Wide Notice',% R/ i, U+ W" Z/ j8 g) k5 X- g2 u
          'search_items' => 'Search Site Wide Notices',
! \7 z8 Y5 u% K& y5 M/ P          'not_found' => 'No site-wide notices found',
: v5 n9 X- X. v+ R+ u$ @5 R) k          'not_found_in_trash' => 'No site-wide notices found in trash'- G% h  I2 F# N# x( W
      );
2 |3 j8 G& J" j. R# u+ M8 n* n! |' `7 n
      $args = array(
3 L( D* W0 k% A; C5 L$ O          'labels' => $labels,
7 Q8 X: [8 B4 w. b% r) Y6 Q          'public' => true,
7 o& W& ^# D( f2 V* |          'has_archive' => true,* _. t4 [- }" U1 L5 B4 T. x* g  V
          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),9 H+ A& G" u. M6 y1 g- o# c
          'taxonomies' => array('category', 'post_tag'),
8 R. e5 L$ L- y6 D+ l6 e1 f- A          'menu_icon' => 'dashicons-megaphone',0 b8 \3 k: m* |
          'menu_position' => 5,
2 i: I; o1 h8 A9 Z1 g& P8 N          'rewrite' => array('slug' => 'site-wide-notices')
$ j9 v  f! M1 G) l, U( u      );
1 e5 k$ ^: K  N$ w/ i2 O9 U) ~: `7 [4 m7 C$ f0 d1 n! N3 I
      register_post_type('site-wide-notices', $args);5 u6 u* ^  F: Z& d( W* Q
   }) ?. F: `' ?2 w
   ```
+ b- K( w; Q" Z! |- C! z$ o7 ]3 }
9 a6 C( i6 p8 N, f3 i   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。6 d) O6 a5 ^- Y/ y
$ I% S' Q4 t& B
3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:$ F6 j3 \8 K; ^6 ~# P9 F
* _' X& g: `* _; V$ S; C
   ```
, {' y$ `6 @- E; J! P' }6 a   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');4 z# Y8 d3 b% ]; h/ D8 u2 ?
   function add_site_wide_notices_boxes() {/ _. Q7 h. V$ p  V
      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');( j0 I4 h- ~8 [& d: o- u' h
   }
& |$ C) k$ C3 U) F, T
6 V4 |1 A& d* E( k% p- a3 K. Z& `( U! `   function notice_details_meta_box($post) {7 _/ t! a. c# i7 H
      wp_nonce_field(basename(__FILE__), 'notices_nonce');! s" L- ?6 N; O! F1 g! _9 ?/ F' G
      $notice_title = get_post_meta($post->ID, 'notice_title', true);: M/ E$ L/ b6 m* w0 |
      $notice_content = get_post_meta($post->ID, 'notice_content', true);. U& N6 C4 y6 P  i1 I
      ?>
' i# C' ^9 ?6 i( N) P1 X      <p>+ D! x. _0 x0 I% D3 w$ P* W6 X; S
          <label for="notice-title">Notice Title</label><br>  C" L: P% O& a# m
          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">
3 q/ r. q& }6 e. b  T) [8 G/ [      </p># c1 @' f2 p" G" P/ ~; c
      <p>
( n9 {7 ?) o% Z$ |3 W          <label for="notice-content">Notice Content</label><br>' M3 K4 v8 w1 }& S* O. y
          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>4 L4 N6 K+ t8 Y0 L
      </p>
. I1 Z* f. \$ Y. ^8 e# b" u      <?php% b1 `, ?7 p+ S3 y/ r7 S' M
   }* r' C% X8 H# E* b: p* l
  Y# r6 Q4 e$ r5 q* o' u. u
   add_action('save_post', 'save_site_wide_notice_meta_box');
# @3 I5 [# c$ g6 m   function save_site_wide_notice_meta_box($post_id) {
2 P9 q) ?8 K. x      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))
6 C9 P7 T7 |5 S7 A- x' `         return;% l0 z5 R8 O" a+ @6 D
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)& o. e% m4 x# h/ c
         return;1 W+ y1 H% H5 @% r! \  ~

8 ]1 z1 z- W4 B8 G+ Q( D      if (isset($_POST['notice_title'])) {" y2 m$ ^7 ^5 S$ g
          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));
, N4 _2 g8 ~% v8 ~+ ^$ ]6 ], S      }5 v, ^2 Z0 B4 K5 H
      if (isset($_POST['notice_content'])) {1 |1 B  \  O, ~0 h" m; R
          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));
. m2 w% [8 U0 f      }
7 J5 B6 v3 H; `( I( Y   }: _4 ]' ^. Y) Y4 _
   ```7 p6 x' D0 L  K4 y- G" n# ~3 v

3 R1 @4 k. |" F- N   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。
, S' b( U! C- y- r. D4 j1 f  R+ x0 S% K/ p1 P4 |1 X8 y1 B
4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:0 _% c- y+ q2 y: v" @

$ b+ E) a0 W% j3 P   ```5 w& u7 x7 ]: a
   $args = array(
3 q" N5 k5 a! S# u+ L/ e      'post_type' => 'site-wide-notices',) `4 Q4 u5 B9 a8 K* W7 a6 ?: v
      'posts_per_page' => 3,/ \; K, X, X% [: {7 {3 p
      'order' => 'DESC',5 D9 p2 q5 `  K+ Y% U( Y' R* Q* ~
      'orderby' => 'date'
1 W7 J& }6 @7 [$ O$ H   );
% `0 m' D, M' Q$ r: Z   $query = new WP_Query($args);
( W& U( ^( S0 w+ [% w9 B   if ($query->have_posts()) :
$ f! ?9 k' b2 U6 M( i* k: z$ B      while ($query->have_posts()) : $query->the_post(); ?>
( N3 G( X; T$ X          <div class="notice">' O0 F* C+ O3 B2 L5 Q  D
              <h3><?php the_title(); ?></h3>6 Z6 ]- I- A0 h+ X( k- F- O
              <div class="notice-content"><?php the_content(); ?></div>5 k- Y% o8 ?7 N, Q) u
          </div>! ]: B1 i" y9 F. a! Z
      <?php endwhile;/ b+ r; ^, u, E# L$ B4 T
      wp_reset_postdata();- v$ t% I. |3 |; _0 `
   endif;6 e$ K3 U! C* o, L  G9 T' m! Z  k$ X! X
   ```
# Z2 L0 x( H3 k- r( \, S
$ l& k! y$ @/ U+ w" H   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-20 18:30 , Processed in 0.013288 second(s), 2 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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