目錄
什麼是「條件標籤」?
More from this category
'.the_title().'
Member Menu
还有其他想法吗?
首頁 後端開發 php教程 釋放條件標籤的力量來增強您的博客

釋放條件標籤的力量來增強您的博客

Aug 28, 2023 am 08:33 AM

釋放條件標籤的力量來增強您的博客

條件標籤是 WordPress 擁有的眾多優秀架構之一,可以幫助我們更輕鬆地進行 WordPress 開發。在本文中,我們將了解其中一些並在範例函數中使用它們,例如從錯誤頁面中刪除內容或更改管理頁面的圖示。


什麼是「條件標籤」?

它們基本上是「是非問題」:當您使用它們時,它們只會傳回 TRUE 或 FALSE。我們在 if 語句中使用它們 - 如果語句為 TRUE 或 FALSE,我們可以根據答案處理我們的程式碼。

您可以在 WordPress Codex 中查看所有條件標籤。

現在,讓我們進入有趣的部分!本文中有十個使用條件標籤的很棒的函數。


功能1. 在首頁顯示彈出訊息 is_front_page()

從主頁向訪客打招呼可能會讓訪客感到愉快,或者您可以對定期維護發出警告,或者可以顯示一個可怕的彈出廣告。無論您需要做什麼,都可以按照以下步驟操作:

首先,您需要在此處取得 Colorbox jQuery 外掛程式。從「colorbox/colorbox」資料夾和colorbox.css取得colorbox.min.js(以及對應的「images」文件夾)複製到主題資料夾內的「colorbox」資料夾。

然後,您需要建立一個 colorbox.load.js 檔案才能載入彈出視窗。也將此檔案放入「colorbox」資料夾:

jQuery(document).ready(function($) {
	var $popup = $("#mypopup");
	$.colorbox({href:$popup});
});
登入後複製

之後,將彈出HTML 程式碼(CSS ID 為「mypopup」)放入主題的index.php 檔案中,並將其隱藏在style.css 檔案(有「#mypopup {display:none;}」)。

function front_popup() {
	if(is_front_page()) {
		// load colorbox.min.js
		wp_enqueue_script('colorbox-js', get_template_directory_uri().'/colorbox/colorbox.min.js',array('jquery'));
		// load colorbox.load.js
		wp_enqueue_script('colorbox-load-js', get_template_directory_uri().'/colorbox/colorbox.load.js',array('colorbox-js'));
		// load colorbox.css
		wp_enqueue_style('colorbox-css', get_template_directory_uri().'/colorbox/colorbox.css');
	}
}
add_action('wp_head','front_popup');
登入後複製

將其貼到您的 functions.php 檔案中,然後就可以開始了!

注意:為了讓彈出視窗消失,您需要在彈出視窗中新增一個連結。這樣就可以了:

<a href="javascript:$.colorbox.close();">Close</a>
登入後複製

功能 2. 使用 is_page() 在特定頁面中包含額外的 CSS 和 JS 程式碼

您可能需要為特定頁面載入一些外部 JavaScript 或 CSS 檔案 - 例如您的「關於」頁面或產品的下載頁面。是的,您也可以將它們包含在您的內容中,但這不是一個好的做法。這是好的做法:

function extra_assets() {
	if(is_page(123)) { // '123' is the ID of the page we are checking for
		wp_enqueue_script('my-script', get_template_directory_uri().'/some/path/in/your/theme/folder/script.js');
		wp_enqueue_style('my-style', get_template_directory_uri().'/some/path/in/your/theme/folder/style.css');
	}
}
add_action('wp_head','extra_assets');
登入後複製

與第一個範例一樣,將其添加到您的 functions.php 檔案中就足夠了。 (不要忘記將“123”號碼更改為您頁面的 ID!)


功能 3. in_category() 特殊類別貼文的「更多此類別」部分

這並不總是必要的,但您可能需要某個類別的「更多來自此類類別」部分(但不是其他類別)。假設您有一個「新聞」類別,而其他類別不適合我們要建立的部分。條件標籤 in_category() 將幫助我們:

function more_from_category($cat_ID) {
	if(in_category($cat_ID) {
		$posts = get_posts('numberposts=5&category='.$cat_ID);
		$output = '<h3 id="More-from-this-category">More from this category</h3>';
		$output.= '<ul>';
		foreach($posts as $post) {
			$output.= '<li><a href="'.get_permalink().'">'.get_the_title.'</a></li>';
		}
		wp_reset_query();
		$output.= '</ul>';
		echo $output;
	}
}
登入後複製

根據需要建立此函數並將其添加到您的 functions.php 檔案中。然後,轉到 single.php 並將程式碼 (<?php more_from_category(123); ?>) 放置在您希望該部分出現的位置。您需要考慮的只是將程式碼放置在循環內。僅此而已!


功能 4. 使用 is_preview() 提醒自己(或您的作者)您仍在預覽頁面上

這不是必須的(畢竟,我們只是學習這些條件標籤的範例),但提醒您自己(或您的作者)顯示的頁面是「預覽」頁面可能是個好主意。將其新增至主題的 functions.php 檔案中:

function preview_warning() {
	if(is_preview()) {
		echo '<div id="preview-warning">Remember, you\'re still on the Preview page!<div>';
	}
}
add_action('the_content','preview_warning');
登入後複製

當然,這還不夠 - 您需要編輯 style.css 來為警告文字提供形狀。像這樣的事情:

#preview-warning {
	background:#800;
	line-height:50px;
	font-size:30px;
	font-weight:bold;
	text-align:center;
	position:fixed;
	bottom:0;
}
登入後複製

給你!


函數 5. 使用 is_404() 從 404 頁面中刪除某些元素

這是所有技巧中最簡單的一個。我認為它甚至不需要解釋 - 只需用下面的程式碼包裝那些“某些元素”(您不想在錯誤頁面上顯示的內容,例如廣告),然後您就可以開始了! p>

if(!is_404()) {
	// Here comes the "certain elements". It's that easy. Seriously.
}
登入後複製

函數 6. 不再使用 has_excerpt() 顯示自動產生的摘錄

我只是討厭自動產生的摘錄。所以我刪除了它們——使用 Codex 中實際提供的程式碼:

function full_excerpt() {
	if (!has_excerpt()) {
		echo '';
	} else { 
		echo get_the_excerpt();
	}
}
登入後複製

將其新增至 functions.php 檔案中,然後您所要做的就是將 the_excerpt() 的實例變更為 full_excerpt()


函数 7. 使用 is_date() 仅列出基于日期的档案中的帖子标题(而不是完整帖子)

有时,在某些存档页面(例如基于日期的存档)上仅列出标题就足够了。因此,例如条件标签 is_date(),我们将删除循环中除标题之外的内容。

这有点棘手,因为每个主题中的 archive.php 文件都不同。 (如果您的主题中有 date.php 文件,您应该编辑该文件。)在代码中查找 The Loop 并使用以下内容更改 The Loop 内的代码:

if(is_date()) {
	// If your theme uses h2 headings for post titles, use h2. If it uses h1, use h1.
	echo '<h2 id="the-title">'.the_title().'</h2>';
} else {
	// ...
	// The original code inside The Loop
	// ...
}
登入後複製

功能 8. 使用 is_admin()

如果您喜欢使用 20 个打开的选项卡(全部用于您的博客),那么此技巧可能会非常方便。只需稍微编辑您的网站图标并将其另存为 adminfav.ico - 例如,我的管理面板网站图标只是我原始网站图标的红色版本

无论如何,您可以这样做:

function admin_favicon() {
	if(is_admin()) {
		echo '<link rel="shortcut icon" href="'.get_bloginfo('url').'/adminfav.ico" />';
	}
}
add_action('admin_head','admin_favicon');
登入後複製

函数9. 如果帖子没有,则显示默认缩略图 has_post_thumbnail()

这是一个好的主题必须具备的条件。如果您的主题中有任何显示特色图像缩略图的部分,您应该the_post_thumbnail() 函数替换为以下代码:

if(has_post_thumbnail()) {
	the_post_thumbnail();
}
else {
	echo '<img class="default-thumb lazy"  src="/static/imghw/default1.png"  data-src="'.get_template_directory_uri().'/images/default-thumb.jpg" .get_template_directory_uri().'/images/default-thumb.jpg" alt="'.get_the_title().'" />';
}
登入後複製

这样,您就可以保持主题外观的一致性。


功能10.使用is_user_logged_in()为您的登录会员显示一个特殊菜单

如果您在 WordPress 中使用会员系统并拥有会员,您可能需要为您登录的会员创建一个特殊的菜单。方法如下:

function member_menu() {
	if(is_user_logged_in()) {
		echo '<div class="member-menu"><h2 id="Member-Menu">Member Menu</h2><ul><li><a href="#">First Menu Item</a></li><li><a href="#">Second Menu Item</a></li><li><a href="#">Third Menu Item</a></li></ul></div>';
	}
}
登入後複製

这是一个标准的“标题和列表”代码,您应该使用该代码使其像您的侧边栏 divs 然后放置代码 <?php member_menu(); ?> 在主题的 sidebar.php 文件中。

此外,这只是一个示例,但理想情况下您可以在此处使用 WordPress 自定义菜单和 wp_nav_menu() 。一项标准和一项会员,然后您可以继续从 WordPress 管理仪表板管理它们。您可以在此处阅读有关 wp_nav_menu() 函数的更多信息。


还有其他想法吗?

这是我最喜欢的 10 个使用条件标签的想法。你的呢?如果您有任何要分享的内容,请在下面发表评论,以便我们可以扩展这篇文章并提供更多想法!

以上是釋放條件標籤的力量來增強您的博客的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

在PHP API中說明JSON Web令牌(JWT)及其用例。 在PHP API中說明JSON Web令牌(JWT)及其用例。 Apr 05, 2025 am 12:04 AM

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

解釋PHP中晚期靜態結合的概念。 解釋PHP中晚期靜態結合的概念。 Mar 21, 2025 pm 01:33 PM

文章討論了PHP 5.3中介紹的PHP中的晚期靜態結合(LSB),允許靜態方法的運行時間分辨率調用以更靈活的繼承。 LSB的實用應用和潛在的觸摸

框架安全功能:防止漏洞。 框架安全功能:防止漏洞。 Mar 28, 2025 pm 05:11 PM

文章討論了框架中的基本安全功能,以防止漏洞,包括輸入驗證,身份驗證和常規更新。

自定義/擴展框架:如何添加自定義功能。 自定義/擴展框架:如何添加自定義功能。 Mar 28, 2025 pm 05:12 PM

本文討論了將自定義功能添加到框架上,專注於理解體系結構,識別擴展點以及集成和調試的最佳實踐。

如何用PHP的cURL庫發送包含JSON數據的POST請求? 如何用PHP的cURL庫發送包含JSON數據的POST請求? Apr 01, 2025 pm 03:12 PM

使用PHP的cURL庫發送JSON數據在PHP開發中,經常需要與外部API進行交互,其中一種常見的方式是使用cURL庫發送POST�...

描述紮實的原則及其如何應用於PHP的開發。 描述紮實的原則及其如何應用於PHP的開發。 Apr 03, 2025 am 12:04 AM

SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

ReactPHP的非阻塞特性究竟是什麼?如何處理其阻塞I/O操作? ReactPHP的非阻塞特性究竟是什麼?如何處理其阻塞I/O操作? Apr 01, 2025 pm 03:09 PM

深入解讀ReactPHP的非阻塞特性ReactPHP的一段官方介紹引起了不少開發者的疑問:“ReactPHPisnon-blockingbydefault....

See all articles