在開(kāi)發(fā)Gutenberg 塊時(shí),正確enqueue 資產(chǎn)的方法包括:1. 使用register_block_type 指定editor_script、editor_style 和style 的路徑;2. 在functions.php 或插件中通過(guò)wp_register_script 和wp_register_style 註冊(cè)資源,並設(shè)置正確的依賴(lài)和版本;3. 配置構(gòu)建工具輸出合適的模塊格式,並確保路徑一致;4. 通過(guò)add_theme_support 或enqueue_block_assets 控制前端樣式的加載邏輯,確保樣式生效且避免衝突。
在開(kāi)發(fā)Gutenberg 塊時(shí),正確地enqueue 資產(chǎn)(比如JavaScript 和CSS 文件)是確保塊正常運(yùn)行的關(guān)鍵步驟。這不僅僅是把文件加載到後臺(tái)編輯器中,還要考慮前端展示和依賴(lài)管理的問(wèn)題。
1. 使用register_block_type
正確指定資產(chǎn)路徑
WordPress 提供了register_block_type
函數(shù)來(lái)註冊(cè)一個(gè)區(qū)塊類(lèi)型,並允許你通過(guò)參數(shù)指定對(duì)應(yīng)的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
:僅在編輯器中加載的樣式,不影響前臺(tái) style
:前後臺(tái)都會(huì)加載的樣式,通常用於區(qū)塊的基本外觀(guān)統(tǒng)一
2. 在functions.php
或插件中註冊(cè)腳本和樣式表
你需要先用wp_register_script
和wp_register_style
註冊(cè)這些資源,這樣WordPress 才能識(shí)別你在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' );
注意幾個(gè)關(guān)鍵點(diǎn):
- 腳本依賴(lài)要寫(xiě)全,比如
wp-blocks
,wp-element
,wp-editor
- 使用
filemtime()
可以避免瀏覽器緩存舊版本文件 - 如果你使用的是主題目錄結(jié)構(gòu),建議用
get_template_directory
;如果是插件,則用plugins_url()
配合__FILE__
3. 構(gòu)建工具配置注意事項(xiàng)
如果你用Webpack、Vite 或其他構(gòu)建工具打包區(qū)塊代碼,需要注意以下幾點(diǎn):
- 輸出的JS 文件應(yīng)該是一個(gè)UMD 模塊,或者被正確打包為適合WordPress 環(huán)境的格式
- 不要把React、ReactDOM 單獨(dú)打包進(jìn)你的腳本,而是通過(guò)WordPress 提供的全局變量引用(如
window.React
,window.ReactDOM
) - 確保輸出路徑與PHP 中註冊(cè)的路徑一致
常見(jiàn)做法:
- 把編輯器腳本放在
/src/blocks/your-block/index.js
- 用Webpack 編譯到
/build/your-block/index.js
- 同時(shí)生成
.asset.php
文件來(lái)自動(dòng)獲取依賴(lài)項(xiàng)和版本號(hào)(WordPress 默認(rèn)支持)
4. 加載前端樣式的小技巧
默認(rèn)情況下,Gutenberg 區(qū)塊的style
參數(shù)會(huì)在前臺(tái)自動(dòng)加載樣式。但有時(shí)候你會(huì)發(fā)現(xiàn)樣式?jīng)]生效,原因可能是:
- 主題沒(méi)有正確啟用區(qū)塊樣式支持(檢查是否調(diào)用了
add_theme_support( 'wp-block-styles' )
) - 樣式被其他主題樣式覆蓋,建議加一些命名空間類(lèi)名
- 有些區(qū)塊不會(huì)在前端渲染(比如某些動(dòng)態(tài)區(qū)塊),這時(shí)候可以考慮用
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ū)塊是否實(shí)際存在頁(yè)面上。
基本上就這些。只要按照WordPress 的區(qū)塊註冊(cè)規(guī)範(fàn)走,再注意構(gòu)建和路徑問(wèn)題,就能順利把資產(chǎn)加載進(jìn)區(qū)塊裡了。
以上是如何爭(zhēng)取古騰堡大塊的資產(chǎn)的詳細(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
用於從照片中去除衣服的線(xiàn)上人工智慧工具。

Clothoff.io
AI脫衣器

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

熱門(mén)文章

熱工具

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

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

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

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

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

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

防止評(píng)論垃圾信息最有效的方式是通過(guò)程序化手段自動(dòng)識(shí)別並攔截。 1.使用驗(yàn)證碼機(jī)制(如GooglereCAPTCHA或hCaptcha)可有效區(qū)分人類(lèi)與機(jī)器人,尤其適合公眾網(wǎng)站;2.設(shè)置隱藏字段(Honeypot技術(shù)),利用機(jī)器人自動(dòng)填寫(xiě)特性識(shí)別垃圾評(píng)論,不影響用戶(hù)體驗(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)站

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

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

robots.txt對(duì)WordPress網(wǎng)站的SEO至關(guān)重要,能引導(dǎo)搜索引擎抓取行為,避免重複內(nèi)容並提升效率。 1.屏蔽如/wp-admin/、/wp-includes/等系統(tǒng)路徑,但避免誤封/uploads/目錄;2.添加Sitemap路徑如Sitemap:https://yourdomain.com/sitemap.xml以幫助搜索引擎快速發(fā)現(xiàn)站點(diǎn)地圖;3.限制/page/和帶參數(shù)的URL以減少爬蟲(chóng)浪費(fèi),但需注意勿封重要?dú)w檔頁(yè);4.避免常見(jiàn)錯(cuò)誤如誤封全站、緩存插件影響更新及忽略移動(dòng)端與子域名配

1.使用性能分析插件可快速定位問(wèn)題,如QueryMonitor可查看數(shù)據(jù)庫(kù)查詢(xún)次數(shù)與PHP錯(cuò)誤,BlackboxProfiler生成函數(shù)執(zhí)行報(bào)告,NewRelic提供服務(wù)器級(jí)分析;2.分析PHP執(zhí)行性能需檢查耗時(shí)函數(shù)、調(diào)試工具使用及內(nèi)存分配情況,如Xdebug生成火焰圖輔助優(yōu)化;3.監(jiān)控?cái)?shù)據(jù)庫(kù)查詢(xún)效率可通過(guò)慢查詢(xún)?nèi)照I與索引檢查,QueryMonitor能列出所有SQL並按時(shí)間排序;4.結(jié)合GooglePageSpeedInsights、GTmetrix與WebPageTest等外部工具評(píng)估前端加

WordPressrequiresatleastPHP7.4,thoughusing8.0orhigherisrecommendedforbetterperformanceandsecurity.Olderversionslike5.6areoutdated,unsupported,andposesecurityrisks.UsingupdatedPHPimprovessecurity,enhancesperformance,andensurescompatibilitywithmodernpl

InspectorControls是Gutenberg開(kāi)發(fā)中用於在右側(cè)邊欄添加自定義控件的組件,1.它屬於@wordpress/block-editor包,2.常搭配PanelBody、TextControl等組件使用,3.使用時(shí)需在edit.js中引入並合理佈局控件類(lèi)型如文本框、下拉選擇、開(kāi)關(guān)、滑動(dòng)條和顏色選擇器等,4.應(yīng)注意分組設(shè)置、保持簡(jiǎn)潔、支持國(guó)際化及優(yōu)化性能。
