wordpress前端多上传,与后端相同

时间:2013-06-04 05:38:11

标签: wordpress image-uploading

我在前端制作了自定义注册表。我想显示与后端相同的上传功能。我不确定如何在前端添加多个上传内容。 任何帮助都非常感谢。

2 个答案:

答案 0 :(得分:3)

wordpress的用户insert_attachment以保存附件,然后您还将具有获取具有不同样式的图像的功能,get_attachment(id,'full / medium / thumbnail')。

    $files = $_FILES['upload_attachment'];
    foreach ($_FILES as $file => $array) {
      $newupload = insert_attachment($file,null);
      // save the $newupload with you from data, as psot id for the attachment
     }
     function  insert_attachment($file_handler,$post_id,$setthumb='false') {

        // check to make sure its a successful upload
        if ($_FILES[$file_handler]['error'] !== UPLOAD_ERR_OK) __return_false();

          require_once(ABSPATH . "wp-admin" . '/includes/image.php');
          require_once(ABSPATH . "wp-admin" . '/includes/file.php');
          require_once(ABSPATH . "wp-admin" . '/includes/media.php');
          $attach_id = media_handle_upload( $file_handler, $post_id );

       if ($setthumb) update_post_meta($post_id,'_thumbnail_id',$attach_id);
         return $attach_id;
     } 

在html中,如果您提交表单,图片将被上传,并且referances将保存在wp_post表中

  <form action="upload_file.php" method="post" enctype="multipart/form-data">
    <label for="file">Filename:</label>
    <input type="file" name="upload_attachment[]" id="file"><br>
    <label for="file">Filename:</label>
    <input type="file" name="upload_attachment[]" id="file"><br>
    <label for="file">Filename:</label>
    <input type="file" name="upload_attachment[]" id="file"><br>
    <input type="submit" name="submit" value="Submit">
  </form>

答案 1 :(得分:1)

<a href="#" class="custom_media_upload">Upload</a>
<img class="custom_media_image" src="" />
<input class="custom_media_url" type="text" name="attachment_url" value="">
<input class="custom_media_id" type="text" name="attachment_id" value="">

jQuery代码:

$('.custom_media_upload').click(function() {

var send_attachment_bkp = wp.media.editor.send.attachment;

wp.media.editor.send.attachment = function(props, attachment) {

    $('.custom_media_image').attr('src', attachment.url);
    $('.custom_media_url').val(attachment.url);
    $('.custom_media_id').val(attachment.id);

    wp.media.editor.send.attachment = send_attachment_bkp;
}

wp.media.editor.open();

return false;       
});