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

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

[复制链接]

344

主题

559

回帖

3646

积分

管理员

积分
3646
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:
7 a2 T+ F0 l$ u! Y7 \& X4 e: x/ A- e1 W- q' a1 I7 n7 b
1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。
. x% x/ [9 V$ _
/ y2 q2 \# _; m. a2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。! `. o6 Y# s5 X) {+ @' j
9 U% f" v- X" ^
3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。
, n  o' `3 X8 P% n& k2 Y( H- t3 S- j) q
4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。: O" W0 M0 H* P, T* ?7 B
2 K6 U9 i- q* y2 p
注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

344

主题

559

回帖

3646

积分

管理员

积分
3646
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?
  ~/ Y4 r  a( [3 ?: Q. Q9 t0 t& I2 J% B$ }& C0 f
如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:  a, r& I! X! P7 O! R% I2 M
( {' K9 B' z, W$ j
1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:
- r( S' I# C  [7 O4 o8 T5 `. P
, I4 y( u) [, @5 f% d# ^9 s# O   ```
8 T: ~; v$ n: u   add_menu_page(% H" n9 V+ {$ J0 f) `
       '全站公告',  z& ?; M/ O+ {: p: r
       '全站公告'," J, _7 X9 b; O* W+ e: [
       'manage_options', //需要的用户权限( Z$ z1 @& e6 O# w
       'site-wide-notice', //后台页面的 slug
8 m, K+ Z! z) O0 t, n! Z       'render_site_wide_notice_page', //用于渲染后台页面内容的函数
3 R) O7 P. I8 O       'dashicons-megaphone', //用于显示在菜单中的图标
6 q  ?0 y7 i/ g% V2 |  u2 D       30 //菜单项的位置
4 Y! h/ s/ u& t7 w8 ^9 c   );7 w' {; a/ n+ y3 F0 }* `
   ```" Y/ X+ R# t& o5 Q7 o

; o2 t# O6 h3 \  q9 d/ j; {   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。3 Z% j/ F; @# k. G
- n( F6 J4 V' U& p% Q
2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:
2 f7 Q# `4 \* I2 f9 P4 b
! U0 M, D9 F1 g# q) K: _8 l   ```
, m5 `4 L: Y# c   function render_site_wide_notice_page() {
! t0 }) Z7 ~# g% }6 L: N      // 渲染后台页面内容
5 k- I/ Z" c/ Z0 J+ o! h# W      echo '<div class="wrap">6 ~9 c. ?' @7 e4 f
          <h2>全站公告</h2>
1 y4 e: H& q/ G/ I          <form method="post" action="">0 f) Y7 A/ l& L# N- n/ p# n  ^
              <label for="title">公告标题:</label>
! R) v$ F! d' F, [              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>3 @6 A( o) x; N( |: T  b
              <label for="content">公告内容:</label>
" K. f* R/ @  t6 a- q& a+ r- X9 {) y              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>
" s% D8 L  Y8 `& [              <input type="submit" name="submit" value="保存设置">; O* y% W. z1 Q" B, s$ U3 z
          </form># Q6 B0 G4 y/ i
      </div>';! w5 [; M0 S3 F0 [
6 R# C! Y3 q4 F) N0 i
      // 处理表单数据- ?  u4 @0 K1 T: q! s
      if (isset($_POST['submit'])) {+ U5 a  v, G9 ^1 A& ]# U
          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));3 I2 e: b+ E2 r; o8 ~
          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));, F( D) p! e3 Z! m. M. \, u* p
      }: @5 b, g! }9 X' V
   }9 l" [$ M7 Y' |
   ```4 p, d7 q( V* H# v0 M
/ I- J$ A7 L6 d
   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。, Y* h! t) R8 }. l. D" `
8 J+ @9 Y7 V; k
3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:
9 y7 I3 @: ?. T. s( t
3 t0 U) h# F: q% `. G( @5 [- X   ```
; l& N/ t* \7 X: z* w# H) b   <?php
. Q; X# |0 }7 O- K% R* _   $site_wide_notice_title = get_option('site_wide_notice_title');8 _, O5 h/ P3 |0 L' q, {4 ~. T
   $site_wide_notice_content = get_option('site_wide_notice_content');" I3 S+ x. l0 A- m! U
   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {3 B8 C; B. i, b0 h1 `* X
       echo '<div class="site-wide-notice">';( Y+ c7 L5 H0 C. @
       if (!empty($site_wide_notice_title)) {
6 u, x% }" I9 n0 i. \1 T+ }5 u           echo '<h3>'.$site_wide_notice_title.'</h3>';1 M0 V# O1 e- b- p& W, m
       }
4 }0 u$ I/ u5 ?# z1 t1 Y2 E1 v  l       if (!empty($site_wide_notice_content)) {! K: M* {- d" P) S# {
           echo '<p>'.$site_wide_notice_content.'</p>';; T$ Z2 L2 ~4 y/ p  j" F5 y$ `% O
       }- W# u7 y5 U: s$ I
       echo '</div>';6 @7 @& v7 N, k, p7 w
   }/ b6 `- C$ i! W* j! v+ U
   ?>  j# w8 H3 Y1 x+ n7 c2 Z/ T  x
   ```& M; h/ I! K3 i* s! f2 \

+ N) W) V% i) a3 H( y   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。4 z* n- x$ [! z1 t! g( W

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

使用道具 举报

344

主题

559

回帖

3646

积分

管理员

积分
3646
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?- a+ O: M' Z- ^3 m, ^4 Q# q4 c
% b/ G( r4 m- R5 ]7 s  r
您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:
! C/ a& C$ u, {* K+ n0 ?& [+ Y: }0 h) d3 R8 q6 G
1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:
2 T2 ~9 S3 d/ K& f% m
+ T  Q* b( n5 Q7 q0 S```
" G; C/ H& J; Cfunction create_custom_post_type() {+ X7 f! }! p, U. F0 |( G( U- m
    $args = array(1 _" B0 A' N+ i. k
        'labels' => array(* a+ f+ {# l0 h7 M
            'name' => '公告',
9 Z0 N% y$ m5 H            'singular_name' => '公告'; U5 W2 J* k: ?; [& F$ [
        ),' d1 t) S. x! ?0 I
        'public' => true,
% s. U* t& d  m        'has_archive' => true,
) {, |/ U6 ~7 s' `9 [1 g        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),( }- U- O2 ?) ^- S( B& @
        'taxonomies' => array('category', 'post_tag'),
2 |9 V. _3 g7 Y1 j/ L        'menu_icon' => 'dashicons-megaphone',- b& g% B; E$ o
        'menu_position' => 5,
) n% r: i3 K. X9 A% U4 @# Z- |9 K        'rewrite' => array('slug' => 'site-wide-notices')
4 j/ x1 k+ k$ J$ U6 s: g    );
% L) r4 h* H5 F4 D  l    register_post_type('site-wide-notices', $args);
) P0 Z) j9 Q/ I0 G+ U& f}4 r  |1 G& |% i" O1 _4 q3 d5 [
add_action('init', 'create_custom_post_type');5 Y, d& `3 f7 n* Y
```
9 O+ |' a' q1 f
& _, H3 a1 V( F- r# I  J在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。
9 ^+ A. r( b- r& q+ d7 w( F
4 z* W& \7 J' s$ A2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。
) r8 R8 U, U' s% p4 A/ X4 W. x$ }& m; S4 n. L1 v) b2 m, j6 w6 ^
3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:% a- N0 D. R2 T! Y

( v! E7 K$ u- M```
$ O, [# _  C  z* M# z$args = array(  C9 K6 ~) g; Q
    'posts_per_page' => 3, // 显示的公告数量3 x+ n. ^8 _: [. B& c" Z: L- C4 Z
    'post_type' => 'site-wide-notices', // 公告文章类型- y' t% B) C+ S/ d
    'post_status' => 'publish', // 公告状态
# A% _9 x  X6 L; D0 |. ~6 F    'order' => 'DESC' // 排序方式1 p( n; m5 {% w. M; s
);
  K8 @' N, x1 Z  V: P
! f8 _# G5 T( V3 J/ ^1 y: `& T$notices = new WP_Query($args);
9 M/ N9 m4 l% f% Fif ($notices->have_posts()) :: s3 C* g7 R6 t- \5 J8 Q
    while ($notices->have_posts()) : $notices->the_post(); ?>
$ X3 w, S3 n- `6 s) H( J6 l0 M        <div class="notice">
0 }" g0 ?- [" P0 N3 e, Z            <h3><?php the_title(); ?></h3>3 D6 `7 @  z0 V. \1 ^  N! d% L+ v1 n
            <div class="notice-content"><?php the_content(); ?></div>. s9 I9 d2 |* @5 O+ D/ N
        </div>' B* p  |5 q; r6 @' T
    <?php endwhile;
  g  Z" J$ @" Y" A6 A0 velse :
6 `7 ?2 u; p" r6 F9 [% E. ]% \    echo "暂无公告";7 U1 Y  u5 I5 \. s% ]- F- I
endif;7 V5 h  m' V3 a
wp_reset_query();
: G5 r" L+ p- q) o4 l```6 i  h! [; K! {. u* i2 r9 v9 B( ]

6 `1 [- Z+ G& u这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。' g4 f2 e; K# t+ n* ?" p' ]4 L
6 w4 A1 ^( v8 P& I( l
以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

344

主题

559

回帖

3646

积分

管理员

积分
3646
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?
( H# a8 i' ~- B* o1 M+ {; Y1 B- t( u- i2 l
如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。
( a$ a/ H8 y8 u8 F, n) t6 i5 O1 Z# d" c: \6 R
以下是创建自定义插件的步骤:
; \% s* L" C3 a3 F. d" u8 `6 c$ L4 w. l* ~/ R9 J9 A3 t0 `
1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:
) a2 V" c* P0 L& P
: y" O* q" w% V. M   ```6 B' x/ b8 |* r4 r& u% ~, n
   <?php
" ^, L. m* Z2 H, w7 U! ?6 b8 l% L   /*
- h3 W8 s5 u* M( n+ j- ]   Plugin Name: Site Wide Notices Plugin
* X) \2 e" i: |! F7 f; `   Description: Adds a new custom post type for site-wide notices.2 r- K( P* [7 m# ~( \
   Version: 1.0. Y6 [# f# F* P, }6 T. A
   Author: Your Name: h! Q" f+ F- b# Q. F* u
   Author URI: http://example.com, t( T' _+ T) E+ x  M; m, N
   */% ~  s. v- P- f
5 }, N  \' u; T% O# @6 A( s0 t0 e- `
   // Add plugin code here.... i- p6 |- T# C* w% j& J
   ```
2 r0 c, w! N$ c* t+ j7 K: u7 E! u+ J; X% L: J& p
   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。
3 z0 z/ n6 w, C7 A7 V: u1 c- a
# e+ B$ r; r7 g! \) E" r2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:
' e; v) H- g4 t
) \& q8 [# V5 m( V# Z   ```
, H9 B4 V, F) [* v. ~. b6 O1 O   add_action('init', 'create_custom_post_type');
9 v6 ]6 M+ {2 ~& c+ P* P   function create_custom_post_type() {
/ H% |! T6 ]) S5 K      $labels = array(
" W8 J# `) j. G0 t- s( S. i4 @2 g          'name' => 'Site Wide Notices',6 u! @0 P9 D7 C
          'singular_name' => 'Site Wide Notice'," F- M7 U5 w  o: o; u: s$ o
          'add_new' => 'Add New',* B0 x. L! h6 F4 d/ S2 X! C
          'add_new_item' => 'Add New Site Wide Notice',
" a: y+ \. L* b* s( j          'edit_item' => 'Edit Site Wide Notice',. g: w4 W- P0 B8 E/ [" i( t
          'new_item' => 'New Site Wide Notice',) s0 m' L* @& `8 R% Q1 O
          'view_item' => 'View Site Wide Notice',
, G3 Z; ~+ S4 d" k. L          'search_items' => 'Search Site Wide Notices',
9 B% f- W: V6 A1 ~: K! i& E, P4 B) C  s          'not_found' => 'No site-wide notices found',
( j% d& j! z4 R( x1 T2 w          'not_found_in_trash' => 'No site-wide notices found in trash'" X: D8 {. A. L0 O- o% ^7 J- D
      );
! F& h. H3 g" M0 R; U. a0 C- I7 p
      $args = array(2 A9 A  V! R3 k1 r3 X3 U
          'labels' => $labels," R5 T, V; j! D# |0 k# Y
          'public' => true,
+ ~2 ~3 U7 ^( ]% ?" c3 h7 ^1 a          'has_archive' => true,! d7 J: J/ m1 ~0 ?; E
          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
  j2 r/ f' ?8 y) N* z; }          'taxonomies' => array('category', 'post_tag'),3 Q4 y( F7 e% u+ ~
          'menu_icon' => 'dashicons-megaphone',
  ~# R6 E% f1 g" Y, n          'menu_position' => 5,
2 J7 R/ e8 _9 n! B2 t: M6 R$ `. f          'rewrite' => array('slug' => 'site-wide-notices')8 e  n6 P  E* A/ J
      );/ L$ a1 s  n: w" g4 ]

/ c  Z- S% }/ ?$ I      register_post_type('site-wide-notices', $args);
/ |7 g( u9 y; j; w- T' z$ Z   }
7 h" R" ^7 W- p   ```' n$ y7 v& w- m  Q8 v! n! X

% j) l# ^1 u# T+ b9 M' F   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。
% y: p- v) F8 B) N! G
' d/ M% A3 S/ k: J: x& X$ v6 h3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:0 v, ^* h& {, u
( Q. x+ \+ N, U% }  ]
   ```% z% I+ q* u4 L* C  H
   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');
+ |0 F- u& o0 q# k6 L4 X   function add_site_wide_notices_boxes() {' N/ ?& S) ^/ D
      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');, `' f$ R: _; D2 `
   }" A3 C9 G- c2 j0 u) e
9 W7 ]0 x3 `; s4 n2 H
   function notice_details_meta_box($post) {% d% v( U* v1 a' `- Z5 h
      wp_nonce_field(basename(__FILE__), 'notices_nonce');) s& Q# |# S" J& Q
      $notice_title = get_post_meta($post->ID, 'notice_title', true);, _. q: x% y! @- ?7 q
      $notice_content = get_post_meta($post->ID, 'notice_content', true);
/ P2 `4 D; N" }$ C      ?>) Z$ e* k0 k% U% ?5 ]# `: i1 x
      <p>
8 @( N( H- I0 e: ~; _0 [& J. c/ C          <label for="notice-title">Notice Title</label><br>5 y6 x$ `- v9 v+ {
          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">& _: o' u- ]' {! N6 r3 z
      </p>  C+ o; Z# C/ d# u+ }  [5 q
      <p>9 ]" c! ~) o9 Y* I
          <label for="notice-content">Notice Content</label><br>- z) f8 l- X. ^' F3 T4 U
          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>' E2 d% Y, x8 g; D3 I
      </p>$ @5 y6 }* S3 R! q# ~  s
      <?php% n, V  r& a2 y+ k  V
   }. B; G7 q  c: y! X4 L+ ?

! ^7 n3 Q, `+ c& ]- m8 z7 a6 G   add_action('save_post', 'save_site_wide_notice_meta_box');' `* R9 L, B+ h) P: ~; v) g" x
   function save_site_wide_notice_meta_box($post_id) {) B! @, l0 A4 j7 J" v% Q
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))
' f& A. k/ K% E( q* Y         return;7 n6 K/ c2 o# L: E) w" [: }# }
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)' v# A+ z0 ?& X- o* t, |
         return;; E. `0 a. c- s

% H- j* D/ _) U% ~3 J$ U) S, x4 f      if (isset($_POST['notice_title'])) {. }6 r8 p6 j/ w. W9 l. N. d2 g/ ]0 o
          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));
+ l' [1 f+ |2 I7 O- h( \0 g0 i9 p      }  d! t  ]4 g  `. i9 v6 ?
      if (isset($_POST['notice_content'])) {( s, a& B+ M1 i7 p& r
          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));0 J; H5 c. @6 E, F
      }
- U$ u9 ~0 L3 Q, `   }5 C; S) w4 `% y
   ```
- J, T3 ^3 `1 ~% N/ p. Q
/ O" w% H, p& b8 R) s   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。
: R+ ^" v- n) b9 o: K  a. e" N6 J0 y, F) O0 q# e
4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:" k# A7 d5 R" D+ \6 B, E3 l3 L

- L% g* W2 r  L. Y& D( ]& Y   ```
* c. G* C: _8 s/ W5 n1 a1 N6 V   $args = array(7 H6 R' J2 \  H0 J# f* o2 B: Z
      'post_type' => 'site-wide-notices',
! Q: C( D7 X. c# s      'posts_per_page' => 3,
# \9 a' R1 L2 K/ c      'order' => 'DESC',5 b3 _  @1 _; m+ Q6 N+ b' p& d
      'orderby' => 'date'
  h) Q8 k7 E4 J5 v   );. V, e1 m( C% v2 T
   $query = new WP_Query($args);
/ _( r( r6 d; e6 I% T3 L   if ($query->have_posts()) :
$ o2 q/ U. q5 q( @1 I      while ($query->have_posts()) : $query->the_post(); ?>0 B9 L  ~4 j; X1 |7 t1 V
          <div class="notice">
" q7 n1 w) K; O4 g              <h3><?php the_title(); ?></h3>; d, b  f, F2 r
              <div class="notice-content"><?php the_content(); ?></div>2 M: J6 O; o9 f% j3 l- \
          </div>" t. S9 U8 r) C3 Z# u# ^
      <?php endwhile;$ G% J0 b2 b1 j% ^; J& b
      wp_reset_postdata();
9 B  T6 g3 d% u   endif;- e& A3 }  `9 O% R; Y, I5 Y
   ```* t3 z* d1 X' t; _( W$ {/ i

! P6 x( R  Y* E" }   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-3 20:23 , Processed in 0.015231 second(s), 2 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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