WordPress 插件開發(fā)入門指南:使用 WordPress 插件樣板
WordPress 插件開發(fā)的學(xué)習(xí)曲線較低,並沒有構(gòu)建插件的唯一方法。插件可以像 Hello Dolly 一樣簡單,只是一個單文件;也可以根據(jù)各種需求和功能構(gòu)建得非常複雜。 WordPress 插件樣板旨在提供一個標(biāo)準(zhǔn)化、高質(zhì)量的基礎(chǔ),幫助您構(gòu)建下一個優(yōu)秀的插件。在本系列的第一部分中,我們將深入探討該樣板,包括文件和文件夾的結(jié)構(gòu)以及樣板的代碼組織。
關(guān)鍵要點
- WordPress 插件樣板為構(gòu)建 WordPress 插件提供了標(biāo)準(zhǔn)化、高質(zhì)量的基礎(chǔ),學(xué)習(xí)曲線低,並且可以靈活地用於簡單或複雜的插件結(jié)構(gòu)。
- 樣板的 3.0.0 版本在代碼組織和插件內(nèi)部關(guān)注點的分離方面帶來了重大改進(jìn),可以通過克隆 git 倉庫或從 GitHub 倉庫下載 zip 文件輕鬆獲取。
- 樣板遵循推薦的 WordPress 編碼和文檔標(biāo)準(zhǔn),提供有用的入門指南和工具推薦,並包含五個用於各種功能的默認(rèn)類,使其成為插件開發(fā)人員的絕佳起點。
背景
WordPress 插件樣板最初是由 Tom McFarlin 發(fā)起的,旨在提供一種標(biāo)準(zhǔn)化的面向?qū)ο蠓椒▉順?gòu)建 WordPress 插件。由於樣板構(gòu)建在插件 API 之上,並遵循 WordPress 推薦的編碼標(biāo)準(zhǔn)和文檔標(biāo)準(zhǔn),因此您可以確信自己處於安全可靠的環(huán)境中。樣板最近更新到 3.0.0 版本,在代碼組織以及插件內(nèi)部關(guān)注點的進(jìn)一步分離方面帶來了重大改進(jìn)。如果您已經(jīng)熟悉使用舊版樣板 (v2.6.2) 開發(fā)插件,則可能需要一些時間來重新學(xué)習(xí)最新版本中的新增內(nèi)容,其中包括新的文件夾結(jié)構(gòu)。此樣板不再由 Tom McFarlin 本人維護(hù)(在撰寫本文時),他已經(jīng)將接力棒傳給了 Devin Vinson。開發(fā)仍在按計劃繼續(xù)進(jìn)行,因此如果您有任何問題,請隨時在 GitHub 倉庫中報告。我們也歡迎您的貢獻(xiàn)。
獲取樣板副本
獲取 WordPress 插件樣板副本最簡單的方法是克隆 git 倉庫本身。
<code>git clone https://github.com/DevinVinson/WordPress-Plugin-Boilerplate.git</code>
或者您可以始終從 GitHub 倉庫下載 zip 文件。由於 3.0.0 版本已發(fā)布,因此不能簡單地將插件直接複製到您的 wp-content/plugins 目錄中。這是因為插件的實際源代碼不包含在根目錄中,而實際上位於名為 trunk 的子目錄中?,F(xiàn)在不用擔(dān)心這個問題,我們稍後將在本文中討論新的文件夾結(jié)構(gòu)。 README.md 文件中詳細(xì)介紹瞭如何正確安裝樣板的完整說明。簡而言之,您可以:
- 將 trunk 目錄複製到 wp-content/plugins 文件夾
- 複製整個樣板目錄,然後為 trunk 子目錄創(chuàng)建到 wp-content/plugins/
/ 的符號鏈接。創(chuàng)建符號鏈接將取決於您使用的操作系統(tǒng)。
完成此操作後,您現(xiàn)在應(yīng)該在管理面板的插件列表中找到一個名為 WordPress Plugin Boilerplate 的插件,假設(shè)您沒有對樣板本身進(jìn)行任何修改。只需激活插件即可開始使用!
使用在線生成器自定義插件
激活後,您將擁有一個基本上不執(zhí)行任何操作的“普通”插件——至少目前是這樣。您還需要對整個樣板的代碼庫運行搜索和替換操作,此過程可能非常繁瑣且耗時。幸運的是,Enrique Chavez 創(chuàng)建了一個非官方生成器,可以自動化此過程。只需訪問 http://ipnx.cn/link/6340831392e9cd8af9598274f4b3c5c0 並填寫頁面底部的表單即可生成個性化的 WordPress 插件樣板副本。
文件夾結(jié)構(gòu)
讓我們更仔細(xì)地看看與舊版本相比,WordPress 插件樣板 3.0.0 版本是如何組織的。如前所述,實際的插件代碼包含在一個名為 trunk 的子目錄中,而不是根目錄中。這是為了遵循 WordPress 官方插件存儲庫中使用的標(biāo)準(zhǔn),該存儲庫包含三個主要目錄:assets、branches 和 trunk。樣板已經(jīng)提供了其中的兩個:assets 和 trunk。以下是樣板中包含的完整目錄和文件(在撰寫本文時):
<code>git clone https://github.com/DevinVinson/WordPress-Plugin-Boilerplate.git</code>
以下是每個文件和文件夾的功能簡要說明:
-
.gitignore
:為大多數(shù)不應(yīng)存在於 git 存儲庫中的內(nèi)容提供合理的默認(rèn).gitignore
。 -
CHANGELOG.md
:樣板更改的標(biāo)準(zhǔn)變更日誌,包含更改日期。 -
README.md
:一個有用的入門指南,其中列出了安裝說明,以及其他一些部分,例如工具推薦和鳴謝。 -
assets
:此目錄包含在您決定將插件發(fā)佈到 WordPress 插件存儲庫時需要提供的推薦資源。此目錄中包含的所有圖像均為發(fā)布的推薦分辨率。 -
trunk
:這是您將要開發(fā)的實際插件。有一些文件夾將代碼庫分為管理和麵向公眾的功能。我們將詳細(xì)介紹每個子目錄的含義。-
admin
:admin
目錄中包含三個目錄,即css
、js
和partials
。顧名思義,所有面向管理的功能都應(yīng)放在此處。默認(rèn)情況下,plugin-name-admin.js
和plugin-name-admin.css
將添加到您的 wp-admin 中。class-plugin-name-admin.php
將提供通用功能,您可以在其中定義特定於管理的掛鉤。 -
public
:此目錄與admin
目錄提供的功能非常相似,唯一的區(qū)別是public
目錄應(yīng)用於存儲所有面向公眾的功能代碼庫。 -
languages
:一個起始.pot
文件,您可以在其中為插件提供翻譯功能。 -
includes
:這可能是幾乎所有神奇之處發(fā)生的地方。默認(rèn)情況下包含五個起始類,我們將在下一節(jié)中討論。 -
LICENSE.txt
:默認(rèn)情況下包含 GPL v2 許可證的副本。 -
README.txt
:插件 README 文件的起點。此文件涵蓋了您可以進(jìn)一步填寫以在 WordPress 插件存儲庫中提供良好的插件頁面的所有部分。 -
plugin-name.php
:插件的入口點。在此處,包含一個通用的插件文件頭,您可以根據(jù)自己的喜好進(jìn)行修改。如果您需要在插件激活和/或停用時包含某種功能,則還會在此文件中註冊register_activation_hook
和register_deactivation_hook
。
-
包含的類
如前所述,trunk/includes
目錄中提供了五個默認(rèn)類。讓我們看看每個類都做什麼:
-
class-plugin-name-activator.php
:此類在插件激活期間實例化。它只有一個靜態(tài)方法activate()
,該方法註冊到register_activation_hook
。每當(dāng)您需要在插件激活時執(zhí)行某些操作(例如創(chuàng)建自定義表或保存默認(rèn)選項)時,請使用此類。 -
class-plugin-name-deactivator.php
:class-plugin-name-deactivator.php
的對應(yīng)類。它也只有一個靜態(tài)方法deactivate()
,可用於在插件停用期間運行任何功能。 -
class-plugin-name-i18n.php
:插件 i18n 功能的起點。它有一個屬性$domain
,用於存儲插件文本域??梢允褂霉卜椒?set_domain()
設(shè)置此屬性。最後,每當(dāng)加載插件時,都會調(diào)用此類中的load_plugin_textdomain()
方法。 -
class-plugin-name-loader.php
:樣板中可能最重要的類。它包含兩個屬性$actions
和$filters
,所有在插件中註冊的掛鉤都將存儲在此處。它提供兩個簡單的包裝函數(shù)add_action()
和add_filter()
,用於將操作或過濾器添加到$actions
和$filters
屬性中。這不要與 WordPress 默認(rèn)的add_action()
和add_filter()
函數(shù)混淆,因為此類實際上並沒有直接註冊它們。所有掛鉤都只會在另一個名為run()
的方法期間註冊。 -
class-plugin-name.php
:將所有部分粘合在一起的類。它包含有關(guān)插件的重要信息,例如插件名稱和版本。此外,它將使用load_dependencies()
方法加載依賴項,這將包含以上四個類,並且將使用set_locale()
方法設(shè)置插件文本域。之前註冊的所有管理和公共掛鉤也可以在此處定義。此類還提供簡單的 get 方法,例如get_plugin_name()
用於返回插件名稱,get_version()
用於返回當(dāng)前插件版本,以及get_loader()
用於保留class-plugin-name-loader.php
的實例。
結(jié)論
簡而言之,WordPress 插件樣板為插件開發(fā)人員提供了一個絕佳的起點。它遵循推薦的 WordPress 編碼標(biāo)準(zhǔn)以及 WordPress 文檔標(biāo)準(zhǔn),因此您知道自己從一開始就走在了正確的道路上。此外,由於樣板已經(jīng)提供了您所需的大部分內(nèi)容,因此發(fā)佈到 WordPress 插件存儲庫變得更加容易。一旦我們熟悉了代碼組織和文件夾結(jié)構(gòu),我們將在本系列的第二部分中探討如何使用 WordPress 插件樣板開發(fā)實際插件。
以上是使用WordPress插件樣板加快開發(fā)的詳細(xì)內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

熱AI工具

Undress AI Tool
免費脫衣圖片

Undresser.AI Undress
人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

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

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6
視覺化網(wǎng)頁開發(fā)工具

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

WordPress導(dǎo)致服務(wù)器CPU使用率飆升的主要原因包括插件問題、數(shù)據(jù)庫查詢效率低、主題代碼質(zhì)量差或流量激增。 1.首先通過top、htop或控制面板工具確認(rèn)是否為WordPress引起的高負(fù)載;2.進(jìn)入故障排查模式逐步啟用插件排查性能瓶頸,使用QueryMonitor分析插件執(zhí)行情況並刪除或替換低效插件;3.安裝緩存插件、清理冗餘數(shù)據(jù)、分析慢查詢?nèi)照I以優(yōu)化數(shù)據(jù)庫;4.檢查主題是否存在過度加載內(nèi)容、複雜查詢或缺乏緩存機制等問題,建議用標(biāo)準(zhǔn)主題測試對比並優(yōu)化代碼邏輯。按照上述步驟逐一排查可定位並解

MinifyingJavaScript文件可通過刪除空白、註釋和無用代碼來提升WordPress網(wǎng)站加載速度。 1.使用支持合併壓縮的緩存插件如W3TotalCache,在“Minify”選項中啟用並選擇壓縮模式;2.使用專用壓縮插件如FastVelocityMinify,提供更精細(xì)控制;3.手動壓縮JS文件並通過FTP上傳,適用於熟悉開發(fā)工具的用戶。注意部分主題或插件腳本可能與壓縮功能衝突,啟用後需徹底測試網(wǎng)站功能。

優(yōu)化WordPress站點不依賴插件的方法包括:1.使用輕量級主題,如Astra或GeneratePress,避免功能堆砌的主題;2.手動壓縮和合併CSS、JS文件,減少HTTP請求;3.上傳前優(yōu)化圖片,使用WebP格式並控製文件大小;4.配置.htaccess啟用瀏覽器緩存,並接入CDN提升靜態(tài)資源加載速度;5.限製文章修訂版本並定期清理數(shù)據(jù)庫冗餘數(shù)據(jù)。

防止評論垃圾信息最有效的方式是通過程序化手段自動識別並攔截。 1.使用驗證碼機制(如GooglereCAPTCHA或hCaptcha)可有效區(qū)分人類與機器人,尤其適合公眾網(wǎng)站;2.設(shè)置隱藏字段(Honeypot技術(shù)),利用機器人自動填寫特性識別垃圾評論,不影響用戶體驗;3.檢查評論內(nèi)容關(guān)鍵詞黑名單,通過敏感詞匹配過濾垃圾信息,需注意避免誤判;4.判斷評論頻率與來源IP,限制單位時間內(nèi)的提交次數(shù)並建立黑名單;5.使用第三方反垃圾服務(wù)(如Akismet、Cloudflare)提升識別準(zhǔn)確性。可根據(jù)網(wǎng)站

TransientsAPI是WordPress中用於臨時存儲可自動過期數(shù)據(jù)的內(nèi)置工具,其核心函數(shù)為set_transient、get_transient和delete_transient。相比OptionsAPI,transients支持設(shè)置生存時間(TTL),適合緩存API請求結(jié)果、複雜計算數(shù)據(jù)等場景。使用時需注意key命名唯一性與命名空間、緩存“懶刪除”機制及對象緩存環(huán)境下可能不持久的問題。典型應(yīng)用場景包括減少外部請求頻率、控制代碼執(zhí)行節(jié)奏和提升頁面加載性能。

在開發(fā)Gutenberg塊時,正確enqueue資產(chǎn)的方法包括:1.使用register_block_type指定editor_script、editor_style和style的路徑;2.在functions.php或插件中通過wp_register_script和wp_register_style註冊資源,並設(shè)置正確的依賴和版本;3.配置構(gòu)建工具輸出合適的模塊格式,並確保路徑一致;4.通過add_theme_support或enqueue_block_assets控制前端樣式的加載邏輯,確保

要添加自定義用戶字段需根據(jù)平臺選擇擴展方式並註意數(shù)據(jù)驗證與權(quán)限控制。常見做法包括:1.利用數(shù)據(jù)庫額外表或鍵值對結(jié)構(gòu)存儲信息;2.在前端加入輸入框並與後端集成;3.對敏感數(shù)據(jù)進(jìn)行格式校驗和訪問權(quán)限限制;4.更新接口及模板以支持新字段展示與編輯,同時兼顧移動端適配和用戶體驗。

在WordPress中添加自定義重寫規(guī)則的關(guān)鍵在於使用add_rewrite_rule函數(shù)並確保規(guī)則正確生效。 1.使用add_rewrite_rule註冊規(guī)則,格式為add_rewrite_rule($regex,$redirect,$after),其中$regex是正則表達(dá)式匹配URL,$redirect指定實際查詢,$after控制規(guī)則位置;2.需通過add_filter添加自定義查詢變量;3.修改後必須刷新固定鏈接設(shè)置;4.建議將規(guī)則放在'top'以避免衝突;5.可藉助插件查看當(dāng)前規(guī)則便於
