Heim  >  Artikel  >  Backend-Entwicklung  >  Einführung in das Hinzufügen fester Felder zu Artikeln in WordPress

Einführung in das Hinzufügen fester Felder zu Artikeln in WordPress

不言
不言Original
2018-07-04 14:04:392956Durchsuche

Dieser Artikel stellt hauptsächlich die Einführung des Hinzufügens fester Felder zu Artikeln in WordPress vor. Jetzt kann ich ihn mit Ihnen teilen.

Lassen Sie WordPress einen Artikel hinzufügen Datentabelle, damit es auf der Artikelbearbeitungsseite bearbeitet und über die Rest-API abgerufen werden kann.

Beispiel: Fügen Sie dem Artikel ein Miniaturbild-Feld-Litpic hinzu

Fügen Sie zunächst über MySQL ein Feld-Litpic zur Artikeltabelle wp_posts hinzu

Fügen Sie dann den folgenden Code nach der Funktion des Themas hinzu. php :

add_action( 'add_meta_boxes', 'myplugin_add_custom_box');
 

add_action( 'save_post', 'myplugin_save_postdata');function myplugin_add_custom_box() {
add_meta_box('myplugin_sectionid',
'设置缩略图', // 可自行修改标题文字
'myplugin_inner_custom_box',
'post');
}function myplugin_inner_custom_box( $post ) {
global $wpdb;
// Use nonce for verification
wp_nonce_field( plugin_basename( __FILE__ ), 
'myplugin_noncename' );
// 获取固定字段litpic的值,用于显示之前保存的值
// 此处wp_posts新添加的字段为litpic,多个用半角逗号隔开
$date = $wpdb->get_row( $wpdb->prepare( "SELECT litpic FROM $wpdb->posts WHERE ID = %d", $post->ID) );
// litpic  字段输入框的HTML代码
echo &#39;<label for="litpic_new_field">图片url </label>&#39;;
echo &#39;<input type="text" id="litpic_new_field" name="litpic_new_field" value="&#39;.$date->litpic.&#39;" size="28" />&#39;;
// 多个字段依此类推
}
function myplugin_save_postdata( $post_id ) {
// verify if this is an auto save routine.
// If it is our form has not been submitted, so we dont want to do anything
if ( defined( ’DOING_AUTOSAVE’ ) && DOING_AUTOSAVE )return;
// verify this came from the our screen and with proper authorization,
// because save_post can be triggered at other times
if ( !wp_verify_nonce( $_POST[&#39;myplugin_noncename&#39;], plugin_basename( __FILE__ ) ) )return;
// 权限验证
if ( &#39;post&#39; == $_POST[&#39;post_type&#39;] ) {
if ( !current_user_can( &#39;edit_post&#39;, $post_id ) )return;
}
// 获取编写文章时填写的固定字段的值,多个字段依此类推
$litpic = $_POST[&#39;litpic_new_field&#39;];global $wpdb;$wpdb->update( "$wpdb->posts",
// 以下一行代码,多个字段的话参照下面的写法,单引号中是字段名,右边是变量值。半角逗号隔开
array( &#39;litpic&#39; => $litpic),
array( &#39;ID&#39; => $post_id ),
// 添加了多少个新字段就写多少个%s,半角逗号隔开
array( &#39;%s&#39;),
array( &#39;%d&#39;)
);
}

Nach dem Hinzufügen wird auf der Artikelseite das Eingabefeld des litpic-Felds angezeigt, wie in der Abbildung gezeigt:

Aber zu diesem Zeitpunkt gibt die restliche API das Litpic-Feld nicht aus.

Öffnen Sie die Datei /wp-includes/rest-api/endpoints/class-wp-rest-posts-controller.php.

Fügen Sie den folgenden Code hinzu:

if ( ! empty( $schema[&#39;properties&#39;][&#39;litpic&#39;] ) ) {            
$data[&#39;litpic&#39;] = $post->litpic;
        }

&#39;litpic&#39;        => array(                    
&#39;description&#39; => __( &#39;A litpic to protect access to the content and excerpt.&#39; ),
                    &#39;type&#39;        => &#39;string&#39;,
                    &#39;context&#39;     => array( &#39;view&#39;, &#39;edit&#39;, &#39;embed&#39; ),
                ),

$post_type_attributes = array(            &#39;title&#39;,
            &#39;editor&#39;,
            &#39;author&#39;,
            &#39;excerpt&#39;,
            &#39;thumbnail&#39;,
            &#39;comments&#39;,
            &#39;revisions&#39;,
            &#39;page-attributes&#39;,
            &#39;post-formats&#39;,
            &#39;custom-fields&#39;,
            &#39;litpic&#39;,
        );        $fixed_schemas = array(            &#39;post&#39; => array(                &#39;title&#39;,
                &#39;editor&#39;,
                &#39;author&#39;,
                &#39;excerpt&#39;,
                &#39;thumbnail&#39;,
                &#39;comments&#39;,
                &#39;revisions&#39;,
                &#39;post-formats&#39;,
                &#39;custom-fields&#39;,
                &#39;litpic&#39;,
            ),

case &#39;litpic&#39;:                    
$schema[&#39;properties&#39;][&#39;litpic&#39;] = array(                        
&#39;description&#39; => __( &#39;The ID for the litpic of the object.&#39; ),
                        &#39;type&#39;        => &#39;string&#39;,
                        &#39;context&#39;     => array( &#39;view&#39;, &#39;edit&#39;, &#39;embed&#39; ),
                    );                    break;

Jetzt kann die Rest-API das Litpic-Feld ausgeben.

Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, er wird für das Studium aller hilfreich sein. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website.

Verwandte Empfehlungen:

Über den ActiveMQ-Stomp-Klassencode

Über Ergänzungen, Löschungen und Änderungen des Yii-Frameworks

Das obige ist der detaillierte Inhalt vonEinführung in das Hinzufügen fester Felder zu Artikeln in WordPress. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Vorheriger Artikel:Laravel-VerzeichnisstrukturNächster Artikel:Laravel-Verzeichnisstruktur