it-swarm.com.de

Wie kann ich mein benutzerdefiniertes Widget in WordPress-Widgets anzeigen lassen? Plugin-Entwicklung

Dies ist mein erstes WordPress-Plugin überhaupt, also bin ich ein bisschen noob. Aber warum wird mein Widget nicht in allen anderen Widgets in meiner WP-Admin-Oberfläche angezeigt? Es sollte sichtbar sein, wenn ich das Plugin aktiviere. Aber es ist nicht. Jede Hilfe dankbar!

enthält/class-level_system-widgets.php

class Level_system_Widgets extends WP_Widget {

    public function __construct(){
        $widget_ops = array( 
            'classname' => 'my_widget',
            'description' => 'My Widget is awesome',
        );
        parent::__construct( 'my_widget', 'My Widget', $widget_ops );
    }

    public function widget( $args, $instance ) {
        // outputs the content of the widget
    }   

    public function form( $instance ) {
        // outputs the options form on admin
    }

    public function update( $new_instance, $old_instance ) {
        // processes widget options to be saved
    }

    public function init() {
        add_action( 'widgets_init', function(){
            register_widget( 'My_Widget' );
        }); 
    }
}

level_system.php

function activate_level_system() {
    require_once plugin_dir_path( __FILE__ ) . 'includes/class-level_system-widgets.php';
    Level_system_Widgets::init();
}
1
slider2013

Meine Antwort wurde basierend auf Ihren Kommentaren aktualisiert. Zuallererst;

Bitte lesen Sie, wie Sie ein Plugin erstellen: https://codex.wordpress.org/Writing_a_Plugin

Zweitens erstellen Sie einen Ordner und Ihre Datei im Verzeichnis wp-content/plugins. Fügen Sie diesen Beispiel-Plugin-Code unten hinzu.

Danach aktivieren Sie bitte das Plugin aus dem Dashboard.

alte Antwort

Wenn Sie Widget als Plugin registrieren, müssen Sie add_action nach Ihrer Klasse verwenden. Widgets werden vor Ihrer Klasse geladen.

add_action('widgets_init', create_function('', 'return register_widget("Level_system_Widgets");'));

Fügen Sie diesen Code nach Ihrer Klasse hinzu (Code aktualisiert mit Beispiel-WordPress-Widgets-API-Code);

neue antwort

<?php 
/*
Plugin Name: Did you try this widget?
Plugin URI: http://www.wpadami.com/
Description: Did you try this widget?
Version: 1
Author: Serkan Algur
Author URI: http://www.wpadami.com
License: GPL2
*/

class Level_system_Widgets extends WP_Widget {

    public function __construct(){
        $widget_ops = array( 
            'classname' => 'level_system_widget',
            'description' => 'Level System Widget',
        );
        parent::__construct( 'level_system_widget', 'Level System Widget', $widget_ops );
    }

    public function widget( $args, $instance ) {
        echo $args['before_widget'];
        if ( ! empty( $instance['title'] ) ) {
            echo $args['before_title'] . apply_filters( 'widget_title', $instance['title'] ) . $args['after_title'];
        }
        echo esc_html__( 'Hello, World!', 'text_domain' );
        echo $args['after_widget'];
    }   

    public function form( $instance ) {
        $title = ! empty( $instance['title'] ) ? $instance['title'] : esc_html__( 'New title', 'text_domain' );
    ?>
    <p>
    <label for="<?php echo esc_attr( $this->get_field_id( 'title' ) ); ?>"><?php esc_attr_e( 'Title:', 'text_domain' ); ?></label> 
    <input class="widefat" id="<?php echo esc_attr( $this->get_field_id( 'title' ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( 'title' ) ); ?>" type="text" value="<?php echo esc_attr( $title ); ?>">
    </p>
    <?php 
    }

    public function update( $new_instance, $old_instance ) {
        $instance = array();
    $instance['title'] = ( ! empty( $new_instance['title'] ) ) ? sanitize_text_field( $new_instance['title'] ) : '';

    return $instance;
    }

}
add_action('widgets_init', create_function('', 'return register_widget("Level_system_Widgets");'));

Working Sample

Dieser Code funktioniert .

0
Serkan Algur