WordPress教程

后台设置页面使用WordPress媒体上传工具上传图片

阿里云

WordPress 的媒体上传工具有着良好的用户体验,即时从来没有接触过 WordPress 的新手,使用一两遍之后也会很快上手。开发 WordPress 设置页面的时候,如果我们需要用户上传图片,直接调用 WordPress 的媒体上传工具是一个非常好的选择。

在本文中,我们将通过简单的几段示例代码,为大家介绍怎么在 WordPress 的设置页面调用 WordPress 的媒体上传工具来实现上传字段。

也想出现在这里?联系我们
创客主机

1、实现需要的 Javascript 代码

首先,我们需要在主题或插件文件夹中创建一个 JavaScript 文件(如:media-uploader.js),该文件中包含如下代码。

  1. jQuery(document).ready(function($){
  2.    var mediaUploader;
  3.    $('#upload_image_button').click(function(e) {
  4.  
  5.      e.preventDefault();
  6.  
  7.      if (mediaUploader) {
  8.        mediaUploader.open();
  9.        return;
  10.      }
  11.  
  12.      mediaUploader = wp.media.frames.file_frame = wp.media({
  13.        title: 'Choose Image',
  14.        button: {
  15.        text: 'Choose Image'
  16.      }, multiple: false });
  17.  
  18.      mediaUploader.on('select', function() {
  19.        var attachment = mediaUploader.state().get('selection').first().toJSON();
  20.  
  21.        // 插入媒体URL到背景图像字段中
  22.        $('#background_image').val(attachment.url);
  23.      });
  24.  
  25.      mediaUploader.open();
  26.    });
  27.  });

上面代码所做的工作很简单,当我们点击 #upload_image_button 按钮时,代码调用 WordPress 的媒体上传工具,用户选择图片后,插入图片网址到 #background_image 字段,作为该字段的值。

创建并保存好上面的代码文件后,下一步,我们需要把这个 JavaScript 文件加载到页面中。

  1. add_action('admin_enqueue_scripts', function () {
  2.      wp_enqueue_media();
  3.      wp_register_script('media-uploader', plugins_url('media-uploader.js', __FILE__ ), array('jquery'));
  4.      wp_enqueue_script('media-uploader');
  5.  });

需要注意的是,因为本示例中,我们开发的是后台页面,需要使用 admin_enqueue_scripts 钩子来加载 JavaScript 文件,如果是前端页面,我们需要使用 wp_enqueue_scripts 钩子。

2、实现表单字段

实现了上传的 JavaScript 功能后,下一步,我们需要在对应的位置插入包含对应 ID 的表单字段。

  1. <input id="background_image" type="text" name="background_image" value="<?php echo get_option('background_image'); ?>" />
  2. <input id="upload_image_button" type="button" class="button-primary" value="Insert Image" />

上面代码实现的表单字段大致如下图所示,点击「Insert Image」按钮,我们就可以调起 WordPress 的媒体上传工具,上传或选择已经上传的图片,然后,插图该图片到前面的 URL 字段中。

如果需要更加良好的用户体验,我们还可以简单调整一下上面的代码,比如,添加一个隐藏的字段用于保存媒体的 ID、添加一个预览字段用于显示缩略图等等。篇幅所限,就不再这里细说了,有需要的朋友可以自行实现。

后台设置页面使用 WordPress 媒体上传工具上传图片

已有 238 人购买
查看演示升级 VIP立刻购买

收藏
(0)

发表回复

热销模板

Ashade - 作品展示摄影相册WordPress汉化主题
LensNews

本站承接 WordPress / PbootCMS / DedeCMS 等
系统建站、仿站、开发、定制等业务!