这是一段有详细注释的WordPress自定义小工具(Widget )开发实例代码,可用于制作主题时集成自定义小工具,将代码添加到主题functions.php中,具体效果如图:
- <?php
- add_action( 'widgets_init', 'example_load_widgets' );
- function example_load_widgets() {
- register_widget( 'Example_Widget' );
- }
- class Example_Widget extends WP_Widget {
-
- function Example_Widget() {
-
- $widget_ops = array( 'classname' => 'example', 'description' => __('An example widget that displays a person\'s name and sex.', 'example') );
-
- $control_ops = array( 'width' => 300, 'height' => 350, 'id_base' => 'example-widget' );
-
- $this->WP_Widget( 'example-widget', __('Example Widget', 'example'), $widget_ops, $control_ops );
- }
-
- function widget( $args, $instance ) {
- extract( $args );
-
- $title = apply_filters('widget_title', $instance['title'] );
- $name = $instance['name'];
- $sex = $instance['sex'];
- $show_sex = isset( $instance['show_sex'] ) ? $instance['show_sex'] : false;
-
- echo $before_widget;
-
- if ( $title )
- echo $before_title . $title . $after_title;
-
- if ( $name )
- printf( '<p>' . __('Hello. My name is %1$s.', 'example') . '</p>', $name );
-
- if ( $show_sex )
- printf( '<p>' . __('I am a %1$s.', 'example.') . '</p>', $sex );
-
- echo $after_widget;
- }
-
- function update( $new_instance, $old_instance ) {
- $instance = $old_instance;
-
- $instance['title'] = strip_tags( $new_instance['title'] );
- $instance['name'] = strip_tags( $new_instance['name'] );
-
- $instance['sex'] = $new_instance['sex'];
- $instance['show_sex'] = $new_instance['show_sex'];
- return $instance;
- }
-
- function form( $instance ) {
-
- $defaults = array( 'title' => __('Example', 'example'), 'name' => __('John Doe', 'example'), 'sex' => 'male', 'show_sex' => true );
- $instance = wp_parse_args( (array) $instance, $defaults ); ?>
- <!-- Widget Title: Text Input -->
- <p>
- <label for="<?php echo $this->get_field_id( 'title' ); ?>"><?php _e('Title:', 'hybrid'); ?></label>
- <input id="<?php echo $this->get_field_id( 'title' ); ?>" name="<?php echo $this->get_field_name( 'title' ); ?>" value="<?php echo $instance['title']; ?>" style="width:100%;" />
- </p>
- <!-- Your Name: Text Input -->
- <p>
- <label for="<?php echo $this->get_field_id( 'name' ); ?>"><?php _e('Your Name:', 'example'); ?></label>
- <input id="<?php echo $this->get_field_id( 'name' ); ?>" name="<?php echo $this->get_field_name( 'name' ); ?>" value="<?php echo $instance['name']; ?>" style="width:100%;" />
- </p>
- <!-- Sex: Select Box -->
- <p>
- <label for="<?php echo $this->get_field_id( 'sex' ); ?>"><?php _e('Sex:', 'example'); ?></label>
- <select id="<?php echo $this->get_field_id( 'sex' ); ?>" name="<?php echo $this->get_field_name( 'sex' ); ?>" class="widefat" style="width:100%;">
- <option <?php if ( 'male' == $instance['format'] ) echo 'selected="selected"'; ?>>male</option>
- <option <?php if ( 'female' == $instance['format'] ) echo 'selected="selected"'; ?>>female</option>
- </select>
- </p>
- <!-- Show Sex? Checkbox -->
- <p>
- <input class="checkbox" type="checkbox" <?php checked( $instance['show_sex'], true ); ?> id="<?php echo $this->get_field_id( 'show_sex' ); ?>" name="<?php echo $this->get_field_name( 'show_sex' ); ?>" />
- <label for="<?php echo $this->get_field_id( 'show_sex' ); ?>"><?php _e('Display sex publicly?', 'example'); ?></label>
- </p>
- <?php
- }
- }
- ?>
原文:http://justintadlock.com/