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

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

[复制链接]

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
发表于 2023-5-18 08:34:20 来自手机 | 显示全部楼层 |阅读模式
您可以使用以下方法来快速在 WordPress 后台增加一个全站公告的功能:2 s( }: U/ D6 E% B: d
2 f' i; @" x% G7 C% K, r' P  Q
1. 在 WordPress 插件库中寻找可用的公告插件,例如 WP Notification Bars、Announcements、SSP Elegant Notification Bar 等。
0 `* {1 h! O+ \6 P/ n
9 h2 I& `. l& l" K) W- J& m2. 安装并激活您选择的插件。您可以在 WordPress 后台的「插件」->「添加新插件」界面中搜索并安装插件,然后在「插件」->「已安装插件」界面中激活它。* A/ B0 X5 i; ?1 G# B8 m

+ p7 H4 q  D5 Q+ A3. 在插件的设置页面中配置您的公告内容和样式。不同插件的设置选项和功能可能会有所不同,但通常都允许您定义公告的文本、链接、颜色、位置等。' A) h# H$ H1 M  I

1 e- ~7 r: y4 w- D6 r4. 将公告添加到您的网站上。在插件设置页面中完成公告的设置后,您可以通过编辑 WordPress 主题的代码或使用插件提供的方法将公告添加到您的网站中。不同插件可能使用不同的添加方法,具体请查看详细说明或联系插件作者。, u+ I: V0 H/ m
% s% j+ _1 A0 x: r4 R
注意,如果您使用的 WordPress 主题已经包含了公告功能,或使用了其他公告插件,可能会导致冲突或功能重复。如果您遇到了这样的问题,请查看主题文档或联系主题作者以获取解决方案。
回复

使用道具 举报

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
 楼主| 发表于 2023-5-18 08:34:51 来自手机 | 显示全部楼层
如果是自己开发的话,具体要怎么做?& A: Z# A# C# c6 m1 i4 h7 n7 A
7 W; J" p5 N. ~: [
如果您自己开发 WordPress 主题或插件,并且需要在后台中增加一个发布全站公告的功能,可以按照以下步骤操作:
9 p* i1 o/ D, y! e+ a3 i0 f8 ~9 C% x  Y# j6 `. v
1. 创建一个自定义的 WordPress 后台页面。您可以使用 `add_menu_page()` 或 `add_submenu_page()` 函数来创建一个自定义后台页面,例如:# F1 k# ]6 g4 d+ S  J
: I* W1 M8 e+ y
   ```
/ Q! a* ^' [% @% v# \% M9 P   add_menu_page(
1 y# W" l8 f+ O! Z/ {       '全站公告',& z3 B( {; n4 U8 [3 Y
       '全站公告',
/ F! d9 `+ o* s' Y: U$ T9 |; n       'manage_options', //需要的用户权限) ?- K! q& z) f+ B
       'site-wide-notice', //后台页面的 slug
5 p+ O7 K0 w* d4 I, h" B       'render_site_wide_notice_page', //用于渲染后台页面内容的函数
8 k1 ]2 A+ A  j8 w2 L" L+ D       'dashicons-megaphone', //用于显示在菜单中的图标4 ]; @- F1 o; W
       30 //菜单项的位置) i+ H( V0 O+ c) s; ~
   );4 s2 {; E& p; N" w6 L8 m/ E5 t- s
   ```
, T! C1 O# {" [7 C5 t9 i+ w, R3 Y
   在该示例中,我们使用 `add_menu_page()` 函数来创建了一个名为“全站公告”的菜单项,并指定需要的用户权限(`manage_options`),在后台页面的 slug 为 `site-wide-notice`,用于渲染后台页面内容的函数为 `render_site_wide_notice_page`,在菜单中显示的图标为 `dashicons-megaphone`,菜单项的位置为 30。) a2 r1 z/ D! r$ j/ j/ _0 Z
0 V4 m, p% ~  O1 D/ W1 u
2. 编写用于显示和保存全站公告内容的代码。您可以在自定义后台页面中创建一个表单,让用户输入公告的标题、内容等信息,并将这些信息保存到 WordPress 数据库中的某个表中。例如:2 h, _$ ]! n$ w

1 G+ ]$ P- p: w+ e# s7 x   ```1 s- Q; ?' {/ O" W
   function render_site_wide_notice_page() {+ Z! F4 F- Y7 W3 N- }
      // 渲染后台页面内容
* s5 {' I! E  U% l* v      echo '<div class="wrap">* N- z* V% L6 v3 S1 q
          <h2>全站公告</h2>6 ]) S2 [' a$ f1 F! w) ~7 F. K* r
          <form method="post" action="">
5 n3 |9 _- s% L9 C              <label for="title">公告标题:</label>
, C! q; c- `, P              <input type="text" name="title" value="'.get_option('site_wide_notice_title').'"><br><br>
  k7 ^9 L( b* [! {  F              <label for="content">公告内容:</label>
' @( q* n4 A* ?- G% F3 k. ?              <textarea name="content">'.get_option('site_wide_notice_content').'</textarea><br><br>
! |% l5 I3 Y* f! R              <input type="submit" name="submit" value="保存设置">
3 E! |( s! ^' o          </form>
" m5 \9 P" g; {# M; W7 W. O2 `5 z# f      </div>';9 h" ?8 k& G/ d( }5 M5 j" t1 A1 u

* V4 h' Y; d! }! b% R* B1 r4 E# Y      // 处理表单数据& Z# [5 s. c  ?. K# w! {1 K. |( H8 E6 P
      if (isset($_POST['submit'])) {
8 z, k& Y$ c$ {          update_option('site_wide_notice_title', sanitize_text_field($_POST['title']));  \) y- Q0 A, e  i) x3 J& M; X3 Q
          update_option('site_wide_notice_content', sanitize_text_field($_POST['content']));
/ P( U% T9 @0 R; t# S+ ~  [! a6 ]      }
/ a- u- c) v% D) F. b; t  f  s   }
$ `& E4 f/ J/ o  J' S: x3 x   ```
+ h+ h/ H$ h( ^/ n* v& ?
/ M/ y# A0 e- S  H5 A, _5 j* M9 ?   在该示例中,我们创建了一个表单,让用户输入公告的标题和内容,并使用 `update_option()` 函数将这些数据保存到名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的 WordPress 配置项中。如果用户点击提交按钮,则将表单数据更新到配置项。* E$ E$ N$ V, \: }8 E- j
8 ?2 Z4 b9 n* L8 C8 S# C% _3 c" B2 u
3. 在 WordPress 主题中显示全站公告。您可以通过在 WordPress 主题的 `header.php` 文件中添加代码,将公告内容显示在网站的顶部或其他位置。例如:) Q4 g: r2 J7 l9 G7 Z# l0 P

7 P3 `& J" B  `1 l7 a3 o   ```- U$ A1 a" R- j7 p8 t9 O
   <?php9 s6 _$ m: s9 N( m! d
   $site_wide_notice_title = get_option('site_wide_notice_title');
/ M1 z; p% L5 F$ n5 o0 ^   $site_wide_notice_content = get_option('site_wide_notice_content');
# z' m5 O* q+ n7 M/ \+ K   if (!empty($site_wide_notice_title) || !empty($site_wide_notice_content)) {, \0 @" U" v( Z; H  S9 @
       echo '<div class="site-wide-notice">';/ Q( S5 F7 p* Q3 B5 I/ P, g5 W
       if (!empty($site_wide_notice_title)) {
6 m; a: E1 b1 S           echo '<h3>'.$site_wide_notice_title.'</h3>';
6 I9 P5 i. x; ~, j- R0 v. Z. G  m; ^       }- C* N; g8 _: G: ]7 |
       if (!empty($site_wide_notice_content)) {
5 L$ y" [+ H6 }6 v2 U# M- J           echo '<p>'.$site_wide_notice_content.'</p>';8 M: I. ~, f0 e5 H+ Q) H
       }6 Y8 z2 l6 o; h( A- p
       echo '</div>';
, {6 w/ Q: z, r; G3 n$ K! B' G   }, A, ~* O) [9 ]! @& Q3 p
   ?>6 _. k$ w$ }) ]1 T8 i' Q7 Y
   ```
$ q, P/ `( K9 x  N$ T" p/ |% h  M* V, _- b/ {* w
   在该示例中,我们检查 WordPress 配置项中名为 `site_wide_notice_title` 和 `site_wide_notice_content` 的值是否为空,如果不为空,则在 `header.php` 文件中添加一个名为 `site-wide-notice` 的容器,将公告标题和内容显示在其中。
7 C" a' h. V  A+ B/ O5 y7 R, o0 B* I+ H1 A) N5 x# v
请注意,本示例仅提供了一个框架,具体实现可能会根据您的需求和实际情况有所不同,您需要根据自己的需要进行修改和调整。同时,为了确保安全性,您还会需要对用户输入的数据进行适当的验证和过滤,例如使用 `sanitize_text_field()` 函数来过滤表单数据。
回复

使用道具 举报

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
 楼主| 发表于 2023-5-18 09:26:50 来自手机 | 显示全部楼层
那如果需要发布多条公告,并进行管理,要如何实现?
# ?1 _4 U4 o4 D# g8 V4 N" y
0 `0 G8 @4 u. q* r9 E+ p您可以创建一个自定义的 WordPress文章类型,例如“公告”,并对其进行自定义化,以实现发布多条公告并进行管理的功能。以下是具体步骤:! y* T6 F* f+ i1 f" I

- i( X  `* c% a" u4 {' u0 {) o) F/ V1. 创建一个自定义的文章类型:在你的主题 `functions.php` 文件中,添加以下代码:+ @# a6 G9 d7 v5 L% r
0 d* R% P9 h1 I+ Q! E
```
  r1 v  M! i: lfunction create_custom_post_type() {/ A- X, B3 c- [( i
    $args = array(
8 U( i$ ^9 l8 Z7 O        'labels' => array(. ?6 J& R, A/ M5 M9 e
            'name' => '公告',* ~) n$ {3 u/ z
            'singular_name' => '公告'1 }+ t  R/ {2 d* K" W4 W
        ),
) ~. c8 l7 c4 _0 O7 F0 r! q        'public' => true,8 e6 D) ]& S6 |9 `; p; n2 X
        'has_archive' => true,
0 g2 Y$ I8 o9 w        'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),
4 `  V; G4 T+ U0 K7 K9 N. ?. S/ \" A/ a        'taxonomies' => array('category', 'post_tag'),
* E" c9 Q  w" a; k6 j        'menu_icon' => 'dashicons-megaphone',
1 D/ r" o. c( n" G/ `, F" N        'menu_position' => 5,, J9 ^; P5 r( ^6 V' o  R9 }
        'rewrite' => array('slug' => 'site-wide-notices')
+ W5 a0 B0 j4 `; h+ n& p+ j0 ~3 k, u    );+ ]9 f4 l/ c0 t- K0 V% Y+ D2 o
    register_post_type('site-wide-notices', $args);0 Q  i  n  }9 \2 V& }" w+ _6 z
}
' q5 I- |6 g/ n  [% ?0 `# G$ [: ]7 w# Ladd_action('init', 'create_custom_post_type');% U8 h$ O- l5 a9 ]
```4 N* a/ I, P$ N" q

# i8 T7 f0 B7 F% o( f# X+ [7 r在示例中,我们注册了一个名为 "site-wide-notices" 的新的文章类型,并定义了文章类型名称、缩略名、文章类型支持的功能、分类法、管理菜单图标等设置。
4 M0 l8 C# |/ z
1 {, I, o# o$ e( j2. 在你的 WordPress 后台中创建新文章类型“公告”:现在,你就可以在 WordPress 后台中通过导航到“公告”菜单,来添加、编辑或删除公告了。您可以在编辑公告的页面中添加标题、内容、特色图像或其他自定义的元数据字段。
) W" I: v$ p1 W1 G$ h2 Y3 h
$ g* I1 T( C" Q) {. @0 E. Q+ _" C3. 在主题中显示公告:在您的 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:% x$ K% C' Q) ^  X  H# M$ i% X' H

- q# J  n7 I! e4 [& g5 W2 e```
7 r% ?6 d; D8 D7 q/ J3 W$args = array(
- H/ x* [0 }9 ^    'posts_per_page' => 3, // 显示的公告数量
$ u9 r9 J0 e! {! J! f    'post_type' => 'site-wide-notices', // 公告文章类型
; l0 Y/ F& l; \' z. n+ z5 t    'post_status' => 'publish', // 公告状态. |, f0 Y& u5 y5 a# f
    'order' => 'DESC' // 排序方式5 I4 V7 V# Y4 C) _$ j$ }! Q
);" E% x- I" J% e- y

" \7 g  u( j& f  P/ M) U* V$notices = new WP_Query($args);
) {6 Z( `9 v8 p4 ]& s6 l5 E: A' hif ($notices->have_posts()) :$ c+ ]# H$ h& Y3 e
    while ($notices->have_posts()) : $notices->the_post(); ?>
7 U! n' @9 x. {, u3 x$ B" R% }        <div class="notice">9 @% L+ r2 {7 }1 _
            <h3><?php the_title(); ?></h3>
0 z5 o0 p% y3 a            <div class="notice-content"><?php the_content(); ?></div>/ n1 k  P: N4 k+ j# F- ^
        </div>
+ S0 O2 i4 Y0 }/ E5 t8 C    <?php endwhile;
) k3 O# ?' z0 o' {9 ~2 Selse :8 N/ P$ o3 M9 T; E
    echo "暂无公告";
7 k8 d8 J' n+ G! [5 H& Gendif;
* w: I% Z& r3 `+ O! v) {( Vwp_reset_query();5 y, w7 K) l) r! {( T
```
$ ]& A/ r6 b% O( }/ G: Y/ A5 Q
8 w, ^, Z3 Y5 U: z- ~* r这段代码将使用 WordPress 的 `WP_Query` 类从公告文章类型中获取最新发布的 3 条公告,并在前端页面中循环遍历并显示公告标题和内容等信息。
0 r) \1 _; G( [$ z/ j; T& O% N  N, }- p" {$ J# [
以上便是实现 Wordpress 后台发布多条全站公告的基本步骤。需要注意的是,自定义文章类型可对应多篇文章,具体根据您的需求进行调整。
回复

使用道具 举报

347

主题

565

回帖

3689

积分

管理员

积分
3689
QQ
 楼主| 发表于 2023-5-18 09:27:55 来自手机 | 显示全部楼层
如果不想修改functions.php,有其他更好的办法吗?
6 ?2 }5 w) ]6 f2 k3 q& S8 ~
0 i* b% O. y9 x5 J. F  W如果您不想修改主题 `functions.php` 文件,也可以创建一个自定义插件来添加新的文章类型。# q3 t  k  a% c" t( g7 n! f7 f

) E7 U8 H) f6 [" |# N) e以下是创建自定义插件的步骤:
  L0 `1 y# \( h$ \, z1 K, g. j+ I4 u9 Y) ?. f/ ^  ^: g- T
1. 创建新插件:在 WordPress 插件目录中创建一个新的子目录,例如 `site-wide-notices-plugin`,然后在该目录中创建一个新的 PHP 文件,例如 `site-wide-notices-plugin.php`,并在文件头部添加必需的标记,例如:8 x% y' L2 r5 R

( e' L: T/ u9 h) [/ w+ m   ```* z) F- \$ J" d( B2 u5 n
   <?php
7 S# U2 {( e0 K- B/ m   /*" N. X$ Y, L* S0 V9 h6 ]
   Plugin Name: Site Wide Notices Plugin
4 U4 y, Q! y9 s8 B& Z   Description: Adds a new custom post type for site-wide notices.
, ^) {3 @. J9 p" L9 A   Version: 1.0' e# O' x3 y$ i3 e$ k" a8 b
   Author: Your Name
- R& D( i: w, h& k' k) P   Author URI: http://example.com/ Z+ B+ o( R; P* _/ Q; m# K/ ?* F
   */
2 l1 i9 E7 `+ ^4 }; a. h1 n0 t, l; C- i3 X
   // Add plugin code here...  i* B0 ^+ B* K4 `  [- e
   ```
& ?6 T# a# {# D2 Q3 g! p# {4 U4 J: a- O% H. z% u4 s! N: H' M
   在示例中,我们创建了一个名为 `Site Wide Notices Plugin` 的新插件,该插件添加了一个新的自定义文章类型,并指定了版本、作者和作者 URI 等元信息。- ^( q: {" O# Z$ k: R9 Y; |6 d
& C8 i- Z$ p5 P8 R0 C. l" `
2. 在插件中注册新的文章类型:在 PHP 文件中添加以下代码,用于注册一个名为“site-wide-notices”的自定义文章类型:
: v( H- f- x$ m* {9 }  D& v" [
   ```& p" j" D& z8 @1 J7 S6 E
   add_action('init', 'create_custom_post_type');
! i4 L1 j& @" H* I! U   function create_custom_post_type() {* e6 H+ T$ Z6 w6 E. s
      $labels = array(
1 d5 r4 r9 O+ E# F, H          'name' => 'Site Wide Notices',) |6 ^9 }% x: A6 V8 V* x+ ]6 b
          'singular_name' => 'Site Wide Notice',
) n7 o- `: ?7 q  _. B3 T( O          'add_new' => 'Add New',
  L  Y) A- \" V6 ^# Q          'add_new_item' => 'Add New Site Wide Notice',
0 i% |( z/ l& G0 X! r          'edit_item' => 'Edit Site Wide Notice',
" P3 r, m/ S* h7 I/ f" U          'new_item' => 'New Site Wide Notice',# z. O3 w7 T" H- e/ O# a; H$ k( o- o9 d
          'view_item' => 'View Site Wide Notice',2 Y6 \' T' F5 Y3 I# x! O
          'search_items' => 'Search Site Wide Notices',
. n. y$ C/ R7 B4 \          'not_found' => 'No site-wide notices found',9 r# K' X3 g: f5 z) u* B$ e" F
          'not_found_in_trash' => 'No site-wide notices found in trash'  b: Y  l4 |) L  ~: E
      );7 d4 i1 z6 @7 ^9 a8 I9 U
; U+ j, Z0 C5 |( a8 W
      $args = array(( B& F  Q) n2 e. C0 @, Q% n3 d1 y
          'labels' => $labels,, N$ @5 F$ @, ?  Z8 M$ ^9 y+ \0 ^
          'public' => true,! S; }8 a4 S* [5 w5 ^  a  X
          'has_archive' => true,! |: P7 H2 F% {$ I- M9 v
          'supports' => array('title', 'editor', 'thumbnail', 'excerpt', 'custom-fields', 'revisions'),% S- M1 X) u5 q( c$ e0 V
          'taxonomies' => array('category', 'post_tag'),
; m+ a  B0 A& _/ B" P          'menu_icon' => 'dashicons-megaphone',
: k. [: D+ z7 B) h          'menu_position' => 5,2 U2 c$ ~/ W5 u# P
          'rewrite' => array('slug' => 'site-wide-notices')
" Q' r- w$ d9 f. y  B' {      );
( Y" H3 f2 R! c5 L" r. V! v% l6 k7 l2 O) y) N7 C
      register_post_type('site-wide-notices', $args);
/ I8 I7 Y. l% N6 Z   }
/ ?! @! X; X* O: Q. H: D  ?. u   ```
1 |3 M/ I+ @+ L) h  {, y
, L# i) h0 i% Z   在示例中,我们使用 `register_post_type()` 函数注册一个新的文章类型,并定义了该文章类型的名称、标签和其他设置。1 q' w7 p) g9 N/ K" z* R
/ R2 P1 R$ [3 e3 A. ^, P
3. 在后台中添加公告编辑页面:您可以使用 `add_meta_box()` 函数在后台中添加公告编辑页面,并自定义字段和元数据,例如:  ]: s  o% g- K: V) ]+ ?& J; j) Q6 _

/ g$ A4 R9 R4 B   ```
) ]; q- H7 Q4 V! h   add_action('add_meta_boxes', 'add_site_wide_notices_boxes');4 [4 L: a+ u. h, E# p5 F2 T
   function add_site_wide_notices_boxes() {4 T8 T9 }8 P8 f5 V& r
      add_meta_box('notice-details', 'Notice Details', 'notice_details_meta_box', 'site-wide-notices', 'normal', 'high');
. B# d% G+ y; i" y   }* |1 H8 t+ S+ V5 I% a* b* T0 r

6 e4 B4 j& O+ J% K6 N& P" {   function notice_details_meta_box($post) {
* w  s0 L2 E: a      wp_nonce_field(basename(__FILE__), 'notices_nonce');$ a# G/ v0 T( c3 ~  s
      $notice_title = get_post_meta($post->ID, 'notice_title', true);/ Q2 W* a( C3 K; y0 k( {4 Q) t
      $notice_content = get_post_meta($post->ID, 'notice_content', true);3 w2 Y, r, s/ b; q$ ^' R7 @, @! C
      ?>; @% o+ v2 a  J
      <p>, ]& l) f% ^# y" M. U
          <label for="notice-title">Notice Title</label><br>5 W* Z6 a- O. B6 l- Q' Z
          <input type="text" id="notice-title" name="notice_title" style="width: 100%;" value="<?php echo $notice_title; ?>">2 T9 y6 C2 ~- z
      </p>/ q$ z# t" M* w& O
      <p>
% ?9 u1 \! x7 s1 I, {6 V; b          <label for="notice-content">Notice Content</label><br>) G) n) h/ p) H  l/ u% l9 K
          <?php wp_editor($notice_content, 'notice-content', array('textarea_rows' => 10)); ?>$ O. S: Z! _! c/ D6 b" @: A- w
      </p>
( y) n( M, M& V* i9 y( e' e% Q      <?php
9 J( N# U8 a5 m. b9 A( P) D+ \. m   }
6 V3 o, }, U/ ?/ j* S" i8 ?3 O: O0 n7 S( s; s; @
   add_action('save_post', 'save_site_wide_notice_meta_box');
5 {9 y9 B% V6 z: S: L) `, L8 [   function save_site_wide_notice_meta_box($post_id) {, x/ M- m. I3 A9 p6 f+ ~
      if (!isset($_POST['notices_nonce']) || !wp_verify_nonce($_POST['notices_nonce'], basename(__FILE__)))
( w, |$ v7 `2 v/ Z8 J+ `+ I) U& Z4 c- s         return;0 {1 L7 z) u2 d5 E; S  Z
      if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)+ Y0 J! a8 s: X, g5 Q1 j: g3 O
         return;
& C0 ]: g8 R  d6 B0 I) @7 v( t0 p7 S# c) Z
      if (isset($_POST['notice_title'])) {6 t3 X* T, @3 w! g/ _" p0 Y6 M# n/ x& k
          update_post_meta($post_id, 'notice_title', sanitize_text_field($_POST['notice_title']));
! C  w0 k4 O; Y# a+ ~' m      }* o# W7 G: W- T
      if (isset($_POST['notice_content'])) {8 P* J  j+ H. q  L  y2 V
          update_post_meta($post_id, 'notice_content', wp_kses_post($_POST['notice_content']));
, s2 I1 K1 R! U2 W$ z( T2 S2 S      }4 k. k8 a8 \. D9 w& C
   }
9 t* ~' z& c- \2 K   ```& J  J  P9 i* U: L- v4 x
  z0 H: I; @+ Q2 a9 ^( \
   在示例中,我们使用 `add_meta_box()` 函数添加了一个名为 `notice-details` 的元框,用于在编辑页面上显示自定义字段和元数据。在 `notice-details_meta_box()` 函数中,我们使用 `wp_editor()` 函数添加了一个可视化编辑器,用于编辑公告内容。在 `save_site_wide_notice_meta_box()` 函数中,我们使用 `update_post_meta()` 函数将公告标题和内容保存到 WordPress 数据库中。
  I+ q* T; i* M/ |) F7 ?$ C! O$ i
! l( ?( e: l1 S) z+ N" q9 U4. 在前端页面中显示公告:在 WordPress 主题文件中添加以下代码,以在您的网站上显示公告:: r9 u! u. ~" f9 y' z. l9 g/ V6 a  e% U
$ H* j; Q/ {7 g) w( ?2 `3 X- H4 l2 D4 W
   ```" z" I3 Q$ U- l; w4 [. L. S* i# V
   $args = array(. U/ P9 L" v3 D" y
      'post_type' => 'site-wide-notices',& @- z$ {7 `( L( X3 H
      'posts_per_page' => 3,1 g9 J1 v1 F7 V8 t2 D0 o8 X
      'order' => 'DESC',
, p) z2 E; d; u# w3 n+ Z; ]5 j( x      'orderby' => 'date'
9 h; i& Q. X- z3 X   );" ^+ N9 v- }. H! M/ ]! G1 H
   $query = new WP_Query($args);( q: [, M6 f% B/ @3 Z7 x& t
   if ($query->have_posts()) :! @* w( E1 Z9 ]
      while ($query->have_posts()) : $query->the_post(); ?>  H! t+ V0 r0 e0 O3 P/ k
          <div class="notice">
& |$ x* K7 {5 B5 d  ]              <h3><?php the_title(); ?></h3>2 L9 p& Q/ j  a' ]5 Y
              <div class="notice-content"><?php the_content(); ?></div>
' y- J1 c9 E! C6 a9 o4 C1 t( d: r          </div>2 r$ l% C. `  G# }& M, V: k
      <?php endwhile;
5 q3 p3 f7 k! i" m      wp_reset_postdata();7 ~. p1 ^2 W9 s: A' f8 r
   endif;3 m9 p$ X4 t* ^
   ```
$ N' W7 ^9 u9 q6 @; d* E% B) }. Y5 u6 y' J2 a; Y" ]/ _5 M- B- C. V
   在示例中,我们使用 `WP_Query` 类从 `site-wide-notices` 文章类型中获取最近发布的 3 条公告,并在前端页面中循环遍历并显示标题和内容等信息。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-18 17:40 , Processed in 0.013050 second(s), 2 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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