Erste Schritte: Die WordPress Customizer JavaScript API verstehen
Der WordPress-Customizer wurde seit seiner Einführung aktiv weiterentwickelt. APIs entwickeln sich ständig weiter, darunter auch JavaScript-APIs. Es handelt sich jedoch um eine der am wenigsten dokumentierten APIs im WordPress-Codex. Daher gibt es nur wenige detaillierte Aufzeichnungen, die zeigen, wie die JavaScript-API tatsächlich genutzt werden kann.
Durch die Nutzung der JavaScript-API im WordPress Customizer können wir tatsächlich ein überzeugenderes Echtzeiterlebnis beim Anpassen eines Themes bieten, anstatt Änderungen nur vom Steuerelement in das Vorschaufenster zu übertragen.
Möglicherweise wissen Sie, wie Sie mit der Customizer-JavaScript-API Änderungen am Vorschaufenster in Echtzeit umsetzen. Dazu richten wir transport
模式设置为 postMessage
ein und fügen den entsprechenden JavaScript-Code wie unten gezeigt hinzu.
wp.customize( 'blogname', function( value ) { value.bind( function( to ) { $( '.site-title a' ).text( to ); } ); } );
Wir können die API jedoch auch weiter erweitern, z. B. Teile, Bedienfelder und Steuerelemente ausblenden, anzeigen oder verschieben, den Wert einer Einstellung basierend auf dem Wert einer anderen Einstellung ändern und Vorschauen und Steuerinteraktionen miteinander verbinden. Dies werden wir uns in diesem Tutorial ansehen.
Schnellstart
Wir haben den WordPress Customizer in mehreren Artikeln und Serien ausführlich behandelt und dabei die Details der Customizer-API behandelt.
Ich denke, Sie haben die Kernkonzepte des WordPress-Customizers und der Komponenten wie Panels, Abschnitte, Einstellungen und Steuerelemente verstanden. Ansonsten empfehle ich Ihnen dringend, einige Zeit damit zu verbringen, unsere Tutorials und Videokurse zu diesem Thema zu studieren, bevor Sie fortfahren.
- WordPress Theme Customizer Guide
- WordPress Theme Customizer
- Schreiben Sie WordPress-Themes, die von Customizern verwendet werden können
Einstellungen und Steuerelemente
Zuerst schauen wir uns die im Customizer für dieses Tutorial hinzugefügten Einstellungen und Steuerelemente an. Wir werden uns auch den Code ansehen, um sie zu implementieren.
In diesem Tutorial konzentrieren wir uns auf den „Website-Titel“ der Website. Wie Sie oben sehen können, verfügen wir über zwei Steuerelemente: das native WordPress-Eingabefeld „Site-Titel“ und ein benutzerdefiniertes Kontrollkästchen zum Aktivieren oder Deaktivieren des „Site-Titels“. Diese beiden Steuerelemente befinden sich im Abschnitt „Site-Identifikation“. Rechts neben dem Bild befindet sich eine Vorschau, in der Sie sehen können, wie der „Site-Titel“ gerendert wird.
Darüber hinaus haben wir, wie Sie unten sehen können, im Abschnitt „Farben“ zwei Steuerelemente zum Ändern der Farbe des Site-Titels und seiner hover
Statusfarbe.
Zugrundeliegender Code
Unser Theme basiert auf Unterstrichen, wobei der gesamte Customizer-bezogene Code in /inc/customizer.php
Dateien abgelegt wird.
function tuts_customize_register( $wp_customize ) { $wp_customize->get_setting( 'blogname' )->transport = 'postMessage'; $wp_customize->get_setting( 'blogdescription' )->transport = 'postMessage'; $wp_customize->get_control( 'blogdescription' )->priority = '12'; $wp_customize->get_setting( 'header_textcolor' )->default = '#f44336'; $wp_customize->get_setting( 'header_textcolor' )->transport = 'postMessage'; // Checkbox to Display Blogname $wp_customize->add_setting( 'display_blogname', array( 'transport' => 'postMessage', ) ); $wp_customize->add_control( 'display_blogname', array( 'label' => __( 'Display Site Title', 'tuts' ), 'section' => 'title_tagline', 'type' => 'checkbox', 'priority' => 11, ) ); // Add main text color setting and control. $wp_customize->add_setting( 'header_textcolor_hover', array( 'default' => '#C62828', 'sanitize_callback' => 'sanitize_hex_color', 'transport' => 'postMessage', ) ); $wp_customize->add_control( new WP_Customize_Color_Control( $wp_customize, 'header_textcolor_hover', array( 'label' => __( 'Header Text Color: Hover', 'tuts' ), 'section' => 'colors', 'priority' => '11' ) ) ); } add_action( 'customize_register', 'tuts_customize_register' );
Wie Sie oben sehen können, haben wir einige Änderungen am Code vorgenommen, um den Anforderungen dieses Tutorials gerecht zu werden.
- Wir haben dafür gesorgt, dass die integrierten WordPress-Einstellungen
blogdescription
降低为12
,以便复选框设置display_blogname
unter dem Eingabefeld „Site-Titel“ angezeigt werden. - Wir erstellen ein Feld namens
display_blogname
的新控件。我们将priority
设置为11
, das in unserem Fall zwischen den Eingabefeldern „Site Title“ und „Tagline“ liegt. - wird
header_text
默认颜色设置为#f44336
,并将transport
类型设置为postMessage
. - Wir haben außerdem eine neue Einstellung erstellt,
header_text_color
。同样,我们还将优先级设置为11
,使其出现在header_textcolor
unter „Einstellungen“.
Alle diese Einstellungen werden über die Option postMessage
设置,而不是通过 refresh
设置。 postMessage
aktiviert, wodurch Werte asynchron übertragen und in Echtzeit im Vorschaufenster angezeigt werden können. Allerdings müssen wir auch unser eigenes JavaScript schreiben, um die Änderungen zu verarbeiten.
JavaScript laden
Wir müssen zwei JavaScript-Dateien erstellen: Eine Datei customizer-preview.js
用于处理预览,另一个文件 customizer-control.js
, um die Steuerelemente im Customizer-Panel zu verwalten. < /p>
js ├── customizer-preview.js // 1. File to handle the Preview ├── customizer-control.js // 2. File to handle the Controls ├── navigation.js └── skip-link-focus-fix.js
Fügen Sie den folgenden Code in customizer-preview.js
ein.
( function( $ ) { // Codes here. } )( jQuery );
Es handelt sich derzeit um eine leere, geschlossene JavaScript-Funktion. Im nächsten Tutorial dieser Serie besprechen wir genauer, wie Sie Änderungen im Vorschaufenster in der Vorschau anzeigen können.
In einer anderen Datei customizer-control.js
fügen wir den folgenden Code hinzu:
(function( $ ) { wp.customize.bind( 'ready', function() { var customize = this; // Codes here } ); })( jQuery );
Wie Sie oben sehen können, werden wir diesen Code im Customizer-Ereignis ready
in diese Datei einbinden. Dadurch wird sichergestellt, dass alles im Customizer, einschließlich Einstellungen, Panels und Steuerelemente, vollständig bereit ist, bevor wir mit der Ausführung benutzerdefinierter Funktionen beginnen.
Nachdem wir den Code hinzugefügt haben, werden wir diese beiden JavaScript-Dateien schließlich an zwei verschiedenen Orten laden.
// 1. customizer-preview.js function tuts_customize_preview_js() { wp_enqueue_script( 'tuts_customizer_preview', get_template_directory_uri() . '/js/customizer-preview.js', array( 'customize-preview' ), null, true ); } add_action( 'customize_preview_init', 'tuts_customize_preview_js' ); // 2. customizer-control.js function tuts_customize_control_js() { wp_enqueue_script( 'tuts_customizer_control', get_template_directory_uri() . '/js/customizer-control.js', array( 'customize-controls', 'jquery' ), null, true ); } add_action( 'customize_controls_enqueue_scripts', 'tuts_customize_control_js' );
customizer-preview.js
文件将通过 customize_preview_init
操作挂钩加载到定制器预览窗口中。 customizer-control.js
文件将加载到定制程序后端,其中的设置和控制元素可通过 customize_controls_enqueue_scripts
操作挂钩访问。
下一步是什么?
WordPress 自成立以来一直在 PHP 方面进行了大量投资。因此,支持该生态系统的大多数开发人员对 PHP API 比 JavaScript API 更加熟练和熟悉也就不足为奇了。
直到最近,它才通过定制器和 WP-API 广泛集成了 JavaScript。掌握 WordPress 定制器中的 JavaScript API 可能是一个相当大的挑战。如前所述,WordPress 的这一面目前记录最少。因此,我们将彻底讨论这个主题。
同时,如果您正在寻找其他实用程序来帮助您构建不断增长的 WordPress 工具集,或者学习代码并更加精通 WordPress,请不要忘记查看我们提供的内容可在 Envato 市场购买。
在此,我们已准备好使用 WordPress JavaScript API 的所有基本元素。我们就到此结束。在本系列的下一部分中,我们将揭示 WordPress 中 JavaScript API 背后的更多内容,并开始编写可立即在主题中实现的功能脚本。
敬请期待!
Das obige ist der detaillierte Inhalt vonErste Schritte: Die WordPress Customizer JavaScript API verstehen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



In Artikel werden JavaScript -Bibliotheken erstellt, veröffentlicht und aufrechterhalten und konzentriert sich auf Planung, Entwicklung, Testen, Dokumentation und Werbestrategien.

In dem Artikel werden Strategien zur Optimierung der JavaScript -Leistung in Browsern erörtert, wobei der Schwerpunkt auf die Reduzierung der Ausführungszeit und die Minimierung der Auswirkungen auf die Lastgeschwindigkeit der Seite wird.

Häufig gestellte Fragen und Lösungen für das Ticket-Ticket-Ticket-Ticket in Front-End im Front-End-Entwicklungsdruck ist der Ticketdruck eine häufige Voraussetzung. Viele Entwickler implementieren jedoch ...

In dem Artikel werden effektives JavaScript -Debuggen mithilfe von Browser -Entwickler -Tools, der Schwerpunkt auf dem Festlegen von Haltepunkten, der Konsole und der Analyse der Leistung erörtert.

Es gibt kein absolutes Gehalt für Python- und JavaScript -Entwickler, je nach Fähigkeiten und Branchenbedürfnissen. 1. Python kann mehr in Datenwissenschaft und maschinellem Lernen bezahlt werden. 2. JavaScript hat eine große Nachfrage in der Entwicklung von Front-End- und Full-Stack-Entwicklung, und sein Gehalt ist auch beträchtlich. 3. Einflussfaktoren umfassen Erfahrung, geografische Standort, Unternehmensgröße und spezifische Fähigkeiten.

In dem Artikel wird erläutert, wie Quellkarten zum Debuggen von JavaScript verwendet werden, indem er auf den ursprünglichen Code zurückgegeben wird. Es wird erläutert, dass Quellenkarten aktiviert, Breakpoints eingestellt und Tools wie Chrome Devtools und WebPack verwendet werden.

Wie fusioniere ich Array -Elemente mit derselben ID in ein Objekt in JavaScript? Bei der Verarbeitung von Daten begegnen wir häufig die Notwendigkeit, dieselbe ID zu haben ...

Eingehende Diskussion der Ursachen des Unterschieds in der Konsole.log-Ausgabe. In diesem Artikel wird die Unterschiede in den Ausgabeergebnissen der Konsolenfunktion in einem Code analysiert und die Gründe dafür erläutert. � ...
