suchen

Heim  >  Fragen und Antworten  >  Hauptteil

javascript - jQuery-File-Upload ist mit IE8 kompatibel. Problem: Die hochgeladene Datei kann keine Antwort erhalten

Geben Sie zunächst den Code für dieses Problem an:
Der folgende Code war erfolgreich mit IE9+ kompatibel, schlug jedoch mit IE8 fehl

 $("#file-upload").fileupload({           
            url: "/api/org/importOrg",
            add: function(e, data) {
                var file = data.files[0];
                $("#fileInput").val(file.name);
                $("#importSuccess").unbind().bind('click', function() {
                    if ($("#fileInput").val() === "") {
                        Messenger().post({
                            message: "请先上传文件!",
                            type: 'info',
                            showCloseButton: true
                        });
                        return;
                    }
                    if (browser == "Microsoft Internet Explorer" && (trim_Version == "MSIE7.0" )) {
                        Messenger().post({
                            message: '浏览器版本过老,不支持导入功能',
                            type: 'info',
                            showCloseButton: true
                        });
                        return;
                    } else if (!/.xls$|.xlsx$/.test(file.name)) {
                        Messenger().post({
                            message: '请上传以.xls/.xlsx为后缀名的正确Excel模版文件',
                            type: 'info',
                            showCloseButton: true
                        });
                        return;
                    } else if (file.size >= 10485760) {//上传文件大小不能超过10Mb
                        Messenger().post({
                            message: '上传的文件大小不能超过10Mb',
                            type: 'info',
                            showCloseButton: true
                        });
                        return;
                    }

                    $('#importSuccess').showLoading({
                        'overlayWidth': $('#importSuccess').innerWidth(),
                        'overlayHeight': $('#importSuccess').innerHeight()
                    });
                    //var pNode = pNodeSelectTree.getId();
                    //$("#file-upload").fileupload({formData: {name: $("#fileInput").val(), //type:$("[name=userType]:checked").val() }});
                    $("#file-upload").fileupload({
                        formData: {
                            name: $("#fileInput").val()
                        }
                    });
                    console.log('before submit:'+ $("#fileInput").val());//before submit:组织导入模板.xls
                    //$("#file-upload").fileupload({url:"/api/org/"+pNode[0]+"/importOrg"});
                    data.submit();
                    console.log("after submit");//after submit
                });
            },
            done: function(e, rep) {
                console.log("done");//没有触发fail,没触发done回掉
                var myResult=JSON.parse(rep.result);//后端返回字符串,解析成JSON对象,请求的content-type应该为text/plain,避免IE9下返回application/json提示下载,从而兼容IE9
              //  myResult={"failed":1,"succeed":10,"fails":[{"line":15,"name":"的萨芬","orgName":"组织","mobile":1352222222,"error":"出错啦!!!"},{"line":15,"name":"的萨芬","orgName":"组织","mobile":1352222222,"error":"出错啦!!!"},{"line":15,"name":"的萨芬","orgName":"组织","mobile":1352222222,"error":"出错啦!!!"}]};
                $('#importSuccess').hideLoading();
                $("#fileInput").val('');
                if (myResult.failed == 0) {
                    new Modal({
                        icon: "success",
                        title: "导入成功",
                        content: "成功导入" + myResult.succeed + "条数据",
                        isConfirm: false
                    }).show(function() {});
                } else {
                    $('#importErrorModal').html(importErrorModal(myResult));
                    new Modal('#importErrorModal').show();
                    $('#importErrorModal td>p').each(function(){
                      this.scrollWidth > this.offsetWidth && $(this).tooltip();
                    });
                    $('#importErrorModal .modal-header').moveAnimate({modalHeaders:'#importErrorModal .modal-header'});
                }

            },
            fail: function() {
                console.log("fail");//没有打印,也就是说没回调fail

                $('#importSuccess').hideLoading();
                $("#fileInput").val('');
            }
        });

Das Problem, auf das ich gestoßen bin, war nicht die sogenannte Rückgabe von JSON-Daten, sondern das Problem, dass der IE-Browser die Downloads verbessert.
Das aktuelle Problem besteht darin, dass dieses Programm unter IE8 die Done- und Fail-Funktionen nicht zurückrufen kann, dies ist jedoch in IE9+-Browsern und anderen Mainstream-Browsern möglich.

  console.log('before submit:'+ $("#fileInput").val());//before submit:组织导入模板.xls
                    //$("#file-upload").fileupload({url:"/api/org/"+pNode[0]+"/importOrg"});
 data.submit();
 console.log("after submit");//after submit

Laut dem Druckergebnis des obigen Programms zeigt es, dass die Add-Funktion erfolgreich ausgeführt wurde.
Ich habe auch die Kommunikation des Netzwerks überwacht. Nur die Datei „loading.gif“ zeigt an, dass die Kommunikation geladen wird, und es gibt keine weiteren entsprechenden Antworten. Die Netzwerkkommunikation von
IE8 sieht folgendermaßen aus:

Dies beweist auch, dass die Funktionen „Done“ und „Fail“ nicht zurückgerufen werden. Was ist also das Problem?

Die Netzwerkkommunikation erfolgreich kompatibler Browser ist wie folgt:

Ich habe gestern versucht, das IE9-Kompatibilitätsproblem zu lösen, aber das IE8-Kompatibilitätsproblem wurde seitdem nicht gelöst. Obwohl ich auch fast einen Tag damit verbracht habe, nach verwandten Problemen beim Stapelüberlauf zu suchen, habe ich nichts gewonnen.

伊谢尔伦伊谢尔伦2766 Tage vor1417

Antworte allen(1)Ich werde antworten

  • PHP中文网

    PHP中文网2017-06-12 09:33:48

    我是题主。我在这个问题上花了两个白天的时间,终于解决了这个问题。
    之所以能解决这个问题,是因为我重新检查了前人写的代码逻辑。这个问题其实和HTML代码紧密相关,我之前只注意JS代码。

    • HTML代码

    <button class="btn btn-icon btn-blue" style="width:90px;height:32px" onclick="$(this).next().click()">
        <span class="icon-zcy icon-shangchuan mr" style="height:20px"></span>上传
    </button>
    <input type="file" name="files" style="display:none" class="btn-upload" id="file-upload" >

    我们可以看到,这个其实是通过click<button>触发click<input type="file">。
    这个是很常见的手法,因为<input type="file">很难看,也不好定制(至少我不知道如何定制它的CSS)。所以通过隐藏input,通过button调用input成为大多数人的选择。
    但是IE8出于安全性,不允许这么做,所以input看似被调用,但是没有获取到data。

    IE doesn't allow manipulation of the type="file" input element from javascript due to security reasons. Setting the filename or invoking a click event to show the browser dialog will result in an "Access is denied" error on the form submit.

    这样如何保证安全性,我就不知道了。

    所以为了避免这个限制,对HTML代码进行改动:看似在点击button,实则在点击
    input

    <p class="uploadFile">
        <input type="text" class="input input-medium" id="fileInput">                       
        <span>
            <a href="javascript:void(0)" class="btn btn-icon btn-blue"  > <span class="icon-zcy icon-shangchuan mr" style="height:20px"></span>上传</a>
            <input type="file" name="files" class="btn-upload" id="file-upload" >
         </span>
    </p>

    SASS

    .uploadFile{
            span{
                position: relative;
                display: inline-block;
            }
            #file-upload { // 设置占据空间为0,看似点击button,实则在点击file-upload,从而避开IE8处于安全限制禁止间接点击input type=file的bug
                position: absolute;
                width: 100%;
                height: 100%;//和父元素同高宽
                top: 0;
                right: 0;
                opacity: 0;
                filter: alpha(opacity=0);
            }//解决此bug的方法详见http://wenzhixin.net.cn/2014/07/30/ie8_file_problem
        }

    这是我看了这篇博客:http://wenzhixin.net.cn/2014/... 后所做的尝试,然后works

    我的感想:通过调试确定问题的根源,再根据问题在谷歌上搜答案。

    Antwort
    0
  • StornierenAntwort