0

我在 WordPress 中有一个函数可以处理将文件上传到 WordPress 图片库。将表单转换为 Ajax 后,我意识到文件上传不再有效。问题是,如果我能在 Ajax 之前执行该函数,它就会起作用。这是代码:

function insert_attachment($file_handler,$post_id,$setthumb='false') {
    if ($_FILES[$file_handler]['error'] !== UPLOAD_ERR_OK){
        return __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;
}

这是我要在调用 Ajax 提交之前执行的调用:

foreach ($_FILES as $file => $array) 
{
    $newupload = insert_attachment($file,$post_id); 
}

原因是$newupload将文件发送到 wordpress 图片库,然后将attachmentIDfor 插入返回到 Ajax 插入的同一个表中。因此,如果代码可以在 Ajax 之前运行,它就可以正常工作。这可能吗?

如何在点击时在后台运行 PHP 函数?

4

1 回答 1

0

PHP 在服务器上而不是在客户端上运行,所以你问的事情只能在服务器上运行。

因此,在服务器上完成 ajax 调用并在回调中使用另一个 ajax 调用。

调用 ajax1 --> 回调 --> 调用 ajax2

像这样

$.ajax({
    url: 'http://www.xxxxxxxxxxxxx',
    data: {name: 'xxxxxx'},
    dataType: 'jsonp',
    success: function(data){

        // do stuff

        // call next ajax function
        $.ajax({ xxx });
    }
});
于 2013-11-05T07:25:26.830 回答