在開發(fā)Gutenberg 塊時,正確enqueue 資產的方法包括:1. 使用register_block_type 指定editor_script、editor_style 和style 的路徑;2. 在functions.php 或插件中通過wp_register_script 和wp_register_style 註冊資源,並設置正確的依賴和版本;3. 配置構建工具輸出合適的模塊格式,並確保路徑一致;4. 通過add_theme_support 或enqueue_block_assets 控制前端樣式的加載邏輯,確保樣式生效且避免衝突。
在開發(fā)Gutenberg 塊時,正確地enqueue 資產(比如JavaScript 和CSS 文件)是確保塊正常運行的關鍵步驟。這不僅僅是把文件加載到後臺編輯器中,還要考慮前端展示和依賴管理的問題。
1. 使用register_block_type
正確指定資產路徑
WordPress 提供了register_block_type
函數來註冊一個區(qū)塊類型,並允許你通過參數指定對應的JS 和CSS 文件路徑。
register_block_type( __DIR__, array( 'editor_script' => 'my-block-editor-script', 'editor_style' => 'my-block-editor-styles', 'style' => 'my-block-frontend-styles', ) );
-
editor_script
:用於區(qū)塊編輯器中的腳本(通常是編譯後的.js
或.jsx
文件) -
editor_style
:僅在編輯器中加載的樣式,不影響前臺 style
:前後臺都會加載的樣式,通常用於區(qū)塊的基本外觀統(tǒng)一
2. 在functions.php
或插件中註冊腳本和樣式表
你需要先用wp_register_script
和wp_register_style
註冊這些資源,這樣WordPress 才能識別你在register_block_type
中提到的handle。
function my_block_assets() { wp_register_script( 'my-block-editor-script', get_template_directory_uri() . '/blocks/my-block/build/index.js', array( 'wp-blocks', 'wp-element', 'wp-editor' ), filemtime( get_template_directory() . '/blocks/my-block/build/index.js' ) ); wp_register_style( 'my-block-editor-styles', get_template_directory_uri() . '/blocks/my-block/editor.css', array(), filemtime( get_template_directory() . '/blocks/my-block/editor.css' ) ); wp_register_style( 'my-block-frontend-styles', get_template_directory_uri() . '/blocks/my-block/style.css', array(), filemtime( get_template_directory() . '/blocks/my-block/style.css' ) ); } add_action( 'init', 'my_block_assets' );
注意幾個關鍵點:
- 腳本依賴要寫全,比如
wp-blocks
,wp-element
,wp-editor
- 使用
filemtime()
可以避免瀏覽器緩存舊版本文件 - 如果你使用的是主題目錄結構,建議用
get_template_directory
;如果是插件,則用plugins_url()
配合__FILE__
3. 構建工具配置注意事項
如果你用Webpack、Vite 或其他構建工具打包區(qū)塊代碼,需要注意以下幾點:
- 輸出的JS 文件應該是一個UMD 模塊,或者被正確打包為適合WordPress 環(huán)境的格式
- 不要把React、ReactDOM 單獨打包進你的腳本,而是通過WordPress 提供的全局變量引用(如
window.React
,window.ReactDOM
) - 確保輸出路徑與PHP 中註冊的路徑一致
常見做法:
- 把編輯器腳本放在
/src/blocks/your-block/index.js
- 用Webpack 編譯到
/build/your-block/index.js
- 同時生成
.asset.php
文件來自動獲取依賴項和版本號(WordPress 默認支持)
4. 加載前端樣式的小技巧
默認情況下,Gutenberg 區(qū)塊的style
參數會在前臺自動加載樣式。但有時候你會發(fā)現樣式沒生效,原因可能是:
- 主題沒有正確啟用區(qū)塊樣式支持(檢查是否調用了
add_theme_support( 'wp-block-styles' )
) - 樣式被其他主題樣式覆蓋,建議加一些命名空間類名
- 有些區(qū)塊不會在前端渲染(比如某些動態(tài)區(qū)塊),這時候可以考慮用
enqueue_block_assets
鉤子按需加載
function my_enqueue_frontend_assets() { if ( has_block( 'my/block-name' ) ) { wp_enqueue_style( 'my-block-frontend-styles' ); } } add_action( 'wp_enqueue_scripts', 'my_enqueue_frontend_assets' );
這種方式更靈活,但也需要判斷區(qū)塊是否實際存在頁面上。
基本上就這些。只要按照WordPress 的區(qū)塊註冊規(guī)範走,再注意構建和路徑問題,就能順利把資產加載進區(qū)塊裡了。
以上是如何爭取古騰堡大塊的資產的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undress AI Tool
免費脫衣圖片

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

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

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

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

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

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

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

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

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

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

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

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

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

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

對象緩存可輔助持久存儲,適用於高訪問低更新、可容忍短暫丟失的數據。 1.適合用緩存“持久化”的數據包括用戶配置、熱門商品信息等,能從數據庫恢復但使用緩存可加速訪問。 2.選擇Redis等支持持久化的緩存後端,啟用RDB或AOF模式,並配置合理過期策略,但不能替代主數據庫。 3.設置長TTL或永不過期鍵,採用清晰鍵名結構如user:1001:profile,修改數據時同步更新緩存。 4.可結合本地與分佈式緩存,本地存小數據、Redis存大數據並用於重啟後恢復,同時注意一致性與資源佔用問題。

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