【问题标题】:How to submit file upload form with ajax? [duplicate]如何使用ajax提交文件上传表单? [复制]
【发布时间】:2011-12-06 13:14:08
【问题描述】:

可能重复:
Ajax file upload

是否可以使用 JQuery 编写一个 ajax 请求来“提交”带有文件字段的表单?我想这样做是因为这样我可以让用户在不离开当前页面的情况下上传文件。

我应该如何编写 $.ajax() 调用?特别是我应该如何设置 ajax 调用文件字段?

编辑:我只想使用核心 JQuery 函数,不使用插件。

谢谢。

【问题讨论】:

  • 在 google.com 甚至这里搜索“jQuery Ajax Upload”会带来很多内容。见:stackoverflow.com/questions/2751795/ajax-file-upload
  • 也许我应该更具体一些。我有一个隐藏的
    标签来保存上传表单。由于我没有使用框架并且我不想使用,因此我需要(如果可能)发送表单(通过 POST)而不刷新页面。

标签: php javascript jquery html forms


【解决方案1】:

为了保持与最广泛的浏览器的兼容性,这需要通过隐藏的 iframe 来完成。

这里有一些示例代码来说明我的意思:

<iframe name="my_iframe" id="my_iframe" style="display: none;"></iframe>

<form action="/next_step.php" method="post" target="my_iframe" entype="multipart/form-data">
    <input type="file" name="file_upload" />
    <input type="button" id="upload_btn" value="Upload file" />

    <label for="name">Name</label>
    <input type="text" name="name" id="name" />

    <input type="submit" value="Next step" />
</form>

<script type="text/javascript">
    var btn = document.getElementById('upload_btn');
    btn.onclick = function(){
        var form_elem = document.forms[0];
        // direct file uploads through the hidden iframe
        form_elem.action = '/test_file.php';
        form_elem.target = 'my_iframe';

        // submit the form
        form_elem.submit();
    };
</script>

有一些项目可以让这更容易,例如Plupload

【讨论】:

  • 看起来我无法从框架中逃脱..
  • 我尝试使用此解决方案,但请求呼叫状态将被取消。数据库中的记录是用空数据创建的。有什么建议吗?
  • @stefun 必须发生某些事情才能取消它,例如离开页面或将另一个文件提交到同一个 iframe。
【解决方案2】:

这很难。你最好使用已经存在的服务。

我最近在一个网站上这样做了,因为我需要在不重新加载页面的情况下提交整个表单,而 uploadify 是我发现的最好的 AJAX 文件上传器。

【讨论】:

  • 有没有插件可以不使用flash显示进度条?
  • 我不这么认为。据我所知,Flash 用于保持文件上传和服务器之间的连接打开,这是较大文件(即您希望在其上显示进度条的文件)所必需的。
  • 我想知道dwr 是否可以做到这一点。他们在那里有一个带有进度条的文件上传演示
  • 我找到了this jquery plugin,它在不使用flash的情况下上传进度条
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2012-07-05
  • 1970-01-01
  • 1970-01-01
  • 2013-04-11
  • 2011-12-10
  • 2017-01-03
  • 1970-01-01
相关资源
最近更新 更多