原生javascript实现文件异步上传

Posted 冷月葬残花

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了原生javascript实现文件异步上传相关的知识,希望对你有一定的参考价值。

效果图:

代码:(demo33.jsp)

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>demo33.jsp</title>
</head>
<body>
<label for="text">名称</label>
<input type="text" id="text" name="name"/>
<label for="file">文件</label>
<input type="file" id="file" name="file"/>
<button type="button" onclick="ajaxUploadFile()">确定</button>
</body>
<script type="text/javascript">
    function ajaxUploadFile() {
        var formData = new FormData();
        var xmlhttp;
        if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
            xmlhttp = new XMLHttpRequest();
        }else {// code for IE6, IE5
            xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
        }
        xmlhttp.open("POST","/data",true);
        xmlhttp.setRequestHeader("X-Requested-With", "XMLHttpRequest");
        formData.append("name",document.getElementById("text").value);
        formData.append("file",document.getElementById("file").files[0]);
        xmlhttp.send(formData);
        xmlhttp.onreadystatechange=function() {
            if (xmlhttp.readyState==4) {
                if (xmlhttp.status==200) {
                    console.log("上传成功"+xmlhttp.responseText);
                }else {
                    console.log("上传失败"+xmlhttp.responseText);
                }
            }
        }
    }
</script>
</html>

以上是关于原生javascript实现文件异步上传的主要内容,如果未能解决你的问题,请参考以下文章

javascript异步提交有几种方法

第65篇 AJAX初识 校验用户名 登录示例 文件上传 csrftoken

原生javaScript中使用Ajax实现异步通信

php 异步上传图片几种方法总结

几个有用的JavaScript/jQuery代码片段(转)

JavaScript实用功能代码片段