創(chuàng)建 Gutenberg 塊的關(guān)鍵在于理解其基本結(jié)構(gòu)并正確連接前后端資源。1. 準(zhǔn)備開發(fā)環(huán)境:安裝本地 WordPress、Node.js 和 @wordpress/scripts;2. 使用 PHP 注冊(cè)塊并用 JavaScript 定義塊的編輯和顯示邏輯;3. 通過(guò) npm 構(gòu)建 JS 文件以使更改生效;4. 遇到問(wèn)題時(shí)檢查路徑、圖標(biāo)是否正確或使用實(shí)時(shí)監(jiān)聽(tīng)構(gòu)建避免重復(fù)手動(dòng)編譯。按照這些步驟,可以逐步實(shí)現(xiàn)一個(gè)簡(jiǎn)單的 Gutenberg 塊。
創(chuàng)建一個(gè)簡(jiǎn)單的 Gutenberg 塊其實(shí)并不難,尤其是如果你已經(jīng)熟悉 WordPress 的基本開發(fā)流程。Gutenberg 是 WordPress 的新編輯器,它通過(guò)“塊”來(lái)組織內(nèi)容,每個(gè)塊就是一個(gè)獨(dú)立的內(nèi)容單元。如果你想自定義一個(gè)自己的塊,可以從最基礎(chǔ)的開始,一步步實(shí)現(xiàn)。
下面是一些實(shí)用步驟和建議,幫你快速上手。
準(zhǔn)備工作:設(shè)置開發(fā)環(huán)境
在開始寫代碼之前,確保你有一個(gè)適合開發(fā)的 WordPress 環(huán)境。你可以使用本地開發(fā)工具(如 Local 或 XAMPP)搭建一個(gè)測(cè)試站點(diǎn)。
- 安裝最新版 WordPress
- 安裝 Node.js 和 npm(用于構(gòu)建 JavaScript 文件)
- 安裝
@wordpress/scripts
包,這是官方推薦的腳本工具集
你可以通過(guò)以下命令安裝必要的依賴:
npm install --save-dev @wordpress/scripts
然后,在你的主題或插件中創(chuàng)建一個(gè)目錄來(lái)存放塊的代碼,比如 /blocks/my-first-block/
。
創(chuàng)建基本結(jié)構(gòu):注冊(cè)塊和編輯組件
一個(gè) Gutenberg 塊通常由兩個(gè)部分組成:PHP 用來(lái)注冊(cè)塊,JavaScript 用來(lái)定義塊的外觀和行為。
PHP 部分(注冊(cè)塊)
在你的主題 functions.php
文件中添加如下代碼,或者在插件中加載:
function register_my_first_block() { wp_register_script( 'my-first-block', get_template_directory_uri() . '/blocks/my-first-block/build/index.js', array( 'wp-blocks', 'wp-element' ) ); register_block_type( 'my-plugin/first-block', array( 'editor_script' => 'my-first-block', ) ); } add_action( 'init', 'register_my_first_block' );
這段代碼告訴 WordPress 這個(gè)塊的 JS 腳本在哪里,并注冊(cè)了一個(gè)新的塊類型。
JavaScript 部分(定義塊)
在 /blocks/my-first-block/src/index.js
中寫入如下內(nèi)容:
const { registerBlockType } = wp.blocks; const { RichText } = wp.editor; registerBlockType( 'my-plugin/first-block', { title: '我的第一個(gè)塊', icon: 'smiley', category: 'common', edit: () => { return ( <RichText tagName="p" placeholder="輸入一些文字..." /> ); }, save: () => { return <RichText.Content tagName="p" value="這是一個(gè)靜態(tài)文本" />; }, } );
這樣你就創(chuàng)建了一個(gè)可以在編輯器中看到的塊了。
構(gòu)建和運(yùn)行:用 npm 編譯 JS 文件
Gutenberg 塊需要將 JavaScript 編譯成瀏覽器可以識(shí)別的格式。你可以使用 WordPress 提供的腳本工具自動(dòng)完成這個(gè)過(guò)程。
在項(xiàng)目根目錄下創(chuàng)建一個(gè) package.json
文件,加入如下配置:
{ "name": "my-first-block", "version": "1.0.0", "scripts": { "build": "wp-scripts build ./blocks/my-first-block/src/index.js" } }
然后運(yùn)行:
npm run build
每次修改完 JS 文件后,都要重新運(yùn)行一次 build
命令,讓更改生效。
小技巧和常見(jiàn)問(wèn)題
圖標(biāo)顯示不出來(lái)? 可以使用 WordPress Dashicons 中的圖標(biāo)名。
塊不顯示? 檢查 JS 是否編譯成功,以及 PHP 注冊(cè)路徑是否正確。
不想每次都手動(dòng)編譯? 可以加上
--watch
參數(shù),實(shí)時(shí)監(jiān)聽(tīng)文件變化并自動(dòng)構(gòu)建:npx wp-scripts build ./blocks/my-first-block/src/index.js --watch
基本上就這些。從零開始創(chuàng)建一個(gè) Gutenberg 塊,關(guān)鍵在于理解塊的基本結(jié)構(gòu)和如何連接前后端資源。雖然看起來(lái)有點(diǎn)復(fù)雜,但只要一步一步來(lái),很快就能掌握。
以上是如何創(chuàng)建一個(gè)簡(jiǎn)單的Gutenberg塊的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

熱AI工具

Undress AI Tool
免費(fèi)脫衣服圖片

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

AI Clothes Remover
用于從照片中去除衣服的在線人工智能工具。

Clothoff.io
AI脫衣機(jī)

Video Face Swap
使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費(fèi)的代碼編輯器

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

禪工作室 13.0.1
功能強(qiáng)大的PHP集成開發(fā)環(huán)境

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

SublimeText3 Mac版
神級(jí)代碼編輯軟件(SublimeText3)

要回滾WordPress版本,可使用插件或手動(dòng)替換核心文件,并禁用自動(dòng)更新。1.使用WPDowngrade等插件輸入目標(biāo)版本號(hào)即可自動(dòng)下載替換;2.手動(dòng)下載舊版WordPress并通過(guò)FTP替換wp-includes、wp-admin等文件但保留wp-config.php和wp-content;3.在wp-config.php中添加代碼或使用過(guò)濾器禁用核心自動(dòng)更新以防止再次升級(jí)。操作前務(wù)必備份網(wǎng)站和數(shù)據(jù)庫(kù),確保安全可靠。長(zhǎng)期建議保持最新版以保障安全性與功能支持。

在WordPress中創(chuàng)建自定義短代碼的步驟如下:1.通過(guò)functions.php文件或自定義插件編寫PHP函數(shù);2.使用add_shortcode()將函數(shù)綁定到短代碼標(biāo)簽;3.在函數(shù)中處理參數(shù)并返回輸出內(nèi)容。例如,創(chuàng)建按鈕短代碼時(shí)可定義顏色和鏈接參數(shù),實(shí)現(xiàn)靈活配置。使用時(shí)可在編輯器中插入類似[buttoncolor="red"url="https://example.com"]點(diǎn)擊這里[/button]的標(biāo)簽,并可通過(guò)do_shortcode()在模

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

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

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

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

對(duì)象緩存可輔助持久存儲(chǔ),適用于高訪問(wèn)低更新、可容忍短暫丟失的數(shù)據(jù)。1.適合用緩存“持久化”的數(shù)據(jù)包括用戶配置、熱門商品信息等,能從數(shù)據(jù)庫(kù)恢復(fù)但使用緩存可加速訪問(wèn)。2.選擇Redis等支持持久化的緩存后端,啟用RDB或AOF模式,并配置合理過(guò)期策略,但不能替代主數(shù)據(jù)庫(kù)。3.設(shè)置長(zhǎng)TTL或永不過(guò)期鍵,采用清晰鍵名結(jié)構(gòu)如user:1001:profile,修改數(shù)據(jù)時(shí)同步更新緩存。4.可結(jié)合本地與分布式緩存,本地存小數(shù)據(jù)、Redis存大數(shù)據(jù)并用于重啟后恢復(fù),同時(shí)注意一致性與資源占用問(wèn)題。

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