Eine andere Möglichkeit, eine Klasse für ein benutzerdefiniertes Widget hinzuzufügen, besteht darin , den Schlüssel ' classname ' Ihrer Konstruktfunktion wie folgt zu verwenden :
class My_Widget_Class extends WP_Widget {
// Prior PHP5 use the children class name for the constructor…
// function My_Widget_Class()
function __construct() {
$widget_ops = array(
'classname' => 'my-class-name',
'description' => __("Widget for the sake of Mankind",'themedomain'),
);
$control_ops = array(
'id_base' => 'my-widget-class-widget'
);
//some more code after...
// Call parent constructor you may substitute the 1st argument by $control_ops['id_base'] and remove the 4th.
parent::__construct(@func_get_arg(0),@func_get_arg(1),$widget_ops,$control_ops);
}
}
Und stellen Sie sicher, dass Sie in Ihrem Design die Standardeinstellung ' before_widget ' verwenden. Wenn Sie diese register_sidebar()
in function.php verwenden, gehen Sie folgendermaßen vor:
//This is just an example.
register_sidebar(array(
'name'=> 'Sidebar',
'id' => 'sidebar-default',
'class' => '',//I never found where this is used...
'description' => 'A sidebar for Mankind',
'before_widget' => '<aside id="%1$s" class="widget %2$s">',//This is the important code!!
'after_widget' => '</aside>',
'before_title' => '<h3>',
'after_title' => '</h3>',
));
Dann haben Sie auf jeder Instanz Ihres Widgets die Klasse 'Widget my-class-name' wie folgt:
<aside class="widget my-class-name" id="my-widget-class-widget-N"><!-- where N is a number -->
<h3>WIDGET TITLE</h3>
<p>WIDGET CONTENT</p>
</aside>
Sie können auch zuerst den übergeordneten Konstruktor aufrufen und dann den gewünschten Klassennamen anhängen:
class My_Widget_Class extends WP_Widget {
// Better defining the parent argument list …
function __construct($id_base, $name, $widget_options = array(), $control_options = array())
{ parent::__construct($id_base, $name, $widget_options, $control_options);
// Change the class name after
$this->widget_options['classname'].= ' some-extra';
}
}