InspectorControls 是 Gutenberg 開發(fā)中用于在右側邊欄添加自定義控件的組件,1. 它屬于 @wordpress/block-editor 包,2. 常搭配 PanelBody、TextControl 等組件使用,3. 使用時需在 edit.js 中引入并合理布局控件類型如文本框、下拉選擇、開關、滑動條和顏色選擇器等,4. 應注意分組設置、保持簡潔、支持國際化及優(yōu)化性能。
在 Gutenberg 開發(fā)中,InspectorControls
是一個非常實用的組件,它用于在編輯器右側邊欄(也就是“塊設置”面板)中添加自定義控件。如果你希望讓用戶能通過側邊欄調整塊的屬性,比如顏色、尺寸或布局選項,那么 InspectorControls
就是你要用到的關鍵工具。
下面是一些常見的使用場景和具體實現方式,幫助你快速上手。
什么是 InspectorControls?
簡單來說,InspectorControls
是 WordPress 的 @wordpress/block-editor
包提供的一個 React 組件。它負責將 UI 控件插入到 Gutenberg 編輯器的右側邊欄中。通常搭配像 PanelBody
、TextControl
、SelectControl
等組件一起使用。
你不能把它直接放在主編輯區(qū)域(Edit 函數里其他地方),只能作為 InspectorControls
的子元素來渲染。
如何添加基本控件
最常見的做法是在你的塊的 edit.js
文件中引入相關組件,并在 InspectorControls
中加入一些控制項。例如:
import { InspectorControls, PanelBody, TextControl } from '@wordpress/block-editor'; import { __ } from '@wordpress/i18n'; export default function Edit( { attributes, setAttributes } ) { const { customText } = attributes; return ( <> <InspectorControls> <PanelBody title={ __( '設置', 'my-block' ) }> <TextControl label={ __( '輸入文字', 'my-block' ) } value={ customText } onChange={ ( value ) => setAttributes( { customText: value } ) } /> </PanelBody> </InspectorControls> <p>{ customText }</p> </> ); }
這樣用戶就能在側邊欄修改顯示的文字內容了。
常見控件類型及用途
你可以根據需求選擇不同的控件類型,以下是一些常用的:
- TextControl:文本輸入框,適合字符串類型的屬性。
- SelectControl:下拉選擇框,適合有限選項的設置。
- ToggleControl:開關按鈕,用于布爾值(true/false)。
- RangeControl:滑動條,適合數值范圍調節(jié)。
- ColorPicker:顏色選擇器,用于顏色設置。
舉個例子,添加一個顏色選擇器可以這樣寫:
import { ColorPicker } from '@wordpress/block-editor'; <ColorPicker color={ colorValue } onChange={ ( value ) => setAttributes( { colorValue: value } ) } />
這些控件都可以組合使用,構建出功能豐富的設置面板。
注意事項與最佳實踐
-
合理分組控件:使用多個
PanelBody
把不同類別的設置分開,提高可讀性。 - 避免過度復雜:不要一次加太多控件,保持界面簡潔。
-
國際化支持:所有文字標簽都應使用
__()
或_x()
進行翻譯。 - 性能優(yōu)化:如果控件很多,考慮懶加載或按需渲染。
基本上就這些。用好 InspectorControls
能顯著提升塊的功能性和用戶體驗,雖然不復雜但容易忽略細節(jié),建議多參考官方文檔和已有插件的實現方式。
以上是如何在Gutenberg使用InspectorControls的詳細內容。更多信息請關注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)

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

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

在開發(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控制前端樣式的加載邏輯,確保

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

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

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

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

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