wp小工具添加自定义图片上传

Published
2022-11-16
浏览次数 :  228

首先要通过admin_enqueue_scripts钩子加载js文件, 首先要加载的是wp_enqueue_media

add_action('admin_enqueue_scripts', 'enqueue_widgets_script');
	# code...

function enqueue_widgets_script() {
	# code...
	wp_enqueue_media();
	wp_enqueue_script('widgetsjs', get_template_directory_uri() . '/js/widgets.js',false,'1.0.0.1',true);
}

然后在小工具class的代码里,添加后台代码, 首先是添加input的字段代码,然后是添加上传的按钮,按钮的id要和js的id相对应,实现打开和上传操作

<p>
        <label for="<?= $this->get_field_name( 'image_uri' ); ?>"><?php _e('Image', 'honghua')?></label>

        <img class="js_custom_upload_media_img" src="<?= (!empty($instance['image_uri'])) ? $instance['image_uri'] : ''; ?>" style="margin:0;padding:0;max-width:100%;display:block"/>

        <input type="text" id="<?php echo $this->get_field_id( 'image_uri' ); ?>" class="widefat js_custom_upload_media_url" name="<?= $this->get_field_name( 'image_uri' ); ?>" value="<?= ($instance['image_uri']) ? esc_attr($instance['image_uri']) : ''; ?>" style="margin-top:5px;" />
				
        <input type="button" id="js_custom_upload_media" class="button button-primary js_custom_upload_media" style="color:white" value="Upload Image" style="margin-top:5px;" />
    </p>

然后是Js文件的部分:

jQuery(document).ready(function ($) {
  function media_upload(button_selector) {
    var _custom_media = true,
      _orig_send_attachment = wp.media.editor.send.attachment;
    $('body').on('click', button_selector, function () {
      var button_id = $(this).attr('id');
      wp.media.editor.send.attachment = function (props, attachment) {
        if (_custom_media) {
          $('.' + button_id + '_img').attr('src', attachment.url);
          $('.' + button_id + '_url').val(attachment.url);
        } else {
          return _orig_send_attachment.apply($('#' + button_id), [props, attachment]);
        }
      }
      wp.media.editor.open($('#' + button_id));
      return false;
    });
  }
  media_upload('.js_custom_upload_media');
});

Top