原型js:ajax提交中缺少输入类型文件

时间:2015-04-08 05:35:01

标签: php ajax forms prototypejs multipartform-data

我创建了一个varien自定义表单,并希望使用原型ajax提交表单。此表单包含四个字段

two text field and 
two file field.

但是当我使用原型j的ajax提交数据时,表单没有通过两个字段并且在enctype =" multipart / form-data"但不起作用。 的代码:

<form action="bt" method="post" enctype="multipart/form-data" name="new-art-upload" id="new-art-upload">
<input type="text" name="fname" value=""   class="input-text required-entry"/>
<input type="text" name="fname" value="" class="input-text required-entry"  />
<input type="file" name="fileone"  class="required-entry"   />
<input type="file" name="filetwo" class="required-entry"   />
<button type="submit" title="<?php echo $this->__('Save The Art') ?>"  class="button newAdd_Sub" onclick="newartUpload.submit(this)"><span><span><?php echo $this->__('Save Art') ?></button>
</form>

脚本:

<script>
    var newartUpload=new VarienForm('new-art-upload');
    newartUpload.submit=function(button,url){
    if(this.validator.validate) {
        var form=this.form;
        var oldUrl = form.action;
        if (url) {
           form.action = url;
        }
        var e=null;
        try{
          // this.form.submit();
           new Ajax.Request(this.form.action,{
            method:this.form.method,
            parameters:this.form.serialize(),
                    contentType: 'multipart/form-data',

            onSuccess:function(transport){
                var response=transport.responseText.evalJSON(true);

            }.bind(this)
            });


        }catch(e){
        }
        if(e){
            throw e;
        }
    }
    }.bind(newartUpload)
</script>

我猜它可能是内容类型,主要是内容类型/

主要问题是文件输入字段未发送到ajax请求

1 个答案:

答案 0 :(得分:3)

您无法通过Ajax使用Prototype提交文件,因为XMLHttpRequest(Ajax的基础)不适用于多部分表单。有一些解决方法,例如使用keyhole iframe发送普通表单请求,以及通过iframe使用回调来重定向或响应外部页面以显示表单已完成。现代JS中的新File接口(在Prototype Ajax接口编写完成后的标准化年份)现在可以通过JS提交发送文件数据,但这是积极的劝阻(并且只能在极少数浏览器中使用,而不是很久以前)所以Prototype只是从它将序列化的表单元素列表中删除文件输入。