我在我的 WordPress 主题中创建了一个小部件来显示图像。到目前为止,该小部件的工作原理是我可以输入值并在前端显示这些值。
当我选择一个小部件并将其放入小部件区域时,媒体上传按钮不起作用。在 WordPress 屏幕的左窗格中,您可以选择要使用的小部件。当我取消隐藏(设置为 display:none)这些小部件的代码,然后使用那里的上传按钮时,它就可以工作了。我猜是因为它在放入小部件区域之前被调用。
我知道 WordPress 为每个小部件添加了独特的参数,因此它们不会相互冲突。所以,我认为我需要将一个唯一参数传递给 .js 文件:#cc-image-upload-file 和 #cc-image-upload-file-button。但我不知道该怎么做。
那么谁能帮我解决这个问题呢?
小部件.php
// Image only
class cc_widget_image extends WP_Widget {
function cc_widget_image() {
$widget_ops = array('classname' => 'cc_widget_image', 'description' => __( 'Select and show an image.', 'cc_language' ) );
$this->WP_Widget('cc_widget_image', 'CC - ' . __( 'Image', 'cc_language' ), $widget_ops);
}
function form($instance) {
$instance = wp_parse_args( (array) $instance, $defaults );
$title = $instance['title'];
$image = $instance['image'];
$checkbox = $instance['checkbox'];
?>
<p>
<label for="<?php echo $this->get_field_id('title'); ?>"><?php _e('Title', 'cc_language'); ?>:
<input id="<?php echo $this->get_field_id('title'); ?>" class="widefat" type="text" name="<?php echo $this->get_field_name('title'); ?>" value="<?php echo $instance['title']; ?>" /></label>
</p>
<p>
<label for="<?php echo $this->get_field_id('image'); ?>"><?php _e('Image', 'cc_language'); ?>:
<input id="<?php echo $this->get_field_id('image'); ?>" class="widefat" type="text" name="<?php echo $this->get_field_name('image'); ?>" value="<?php echo $instance['image']; ?>" /></label>
</p>
<p>
<label for="cc-image-upload-file"><?php _e('Image', 'cc_language'); ?>:</label><br>
<label for="cc-image-upload-file">
<input type="text" id="cc-image-upload-file" class="widefat" name="<?php echo $this->get_field_name('image'); ?>" value="<?php echo $instance['image']; ?>" />
<input type="button" id="cc-image-upload-file-button" class="button" value="Upload file" />
<label for="cc-image-upload-file"><span class="description">Enter URL or upload file</span></label>
</label>
</p>
<p>
<label for="<?php echo $this->get_field_id('checkbox'); ?>"><?php _e('Do not show title', 'cc_language'); ?></label>
<input id="<?php echo $this->get_field_id('checkbox'); ?>" type="checkbox" name="<?php echo $this->get_field_name('checkbox'); ?>" value="true" <?php checked( 'true', $checkbox ); ?> />
</p>
<?php
}
function update($new_instance, $old_instance) {
$instance = $old_instance;
$instance['title'] = strip_tags($new_instance['title']);
$instance['image'] = $new_instance['image'];
$instance['checkbox'] = strip_tags($new_instance['checkbox']);
return $instance;
}
function widget($args, $instance) {
extract($args, EXTR_SKIP);
$title = apply_filters('widget_title', empty($instance['title']) ? __('Image') : $instance['title'], $instance, $this->id_base);
echo $before_widget;
// display the widget title
if ( $instance['checkbox'] == 'true' ) {
} else {
if ( $title )
echo $before_title . $title . $after_title;
}
// display the widget content
echo the_post_thumbnail(array(220,200));
echo $instance['image'];
echo $after_widget;
}
}
add_action( 'widgets_init', create_function('', 'return register_widget("cc_widget_image");') );
媒体上传.js
jQuery(document).ready(function($){
var custom_uploader;
$('#cc-image-upload-file-button').click(function(e) {
e.preventDefault();
//If the uploader object has already been created, reopen the dialog
if (custom_uploader) {
custom_uploader.open();
return;
}
//Extend the wp.media object
custom_uploader = wp.media.frames.file_frame = wp.media({
title: 'Choose File',
button: {
text: 'Choose File'
},
multiple: false
});
//When a file is selected, grab the URL and set it as the text field's value
custom_uploader.live('select', function() {
attachment = custom_uploader.state().get('selection').first().toJSON();
$('#cc-image-upload-file').val(attachment.url);
});
//Open the uploader dialog
custom_uploader.open();
});
});