利用js/jq 利用FormData 对象和ajax上传文件

new FormData(); 可以获取某个表单,但是有时候感觉不太灵活。可以利用jq获取指定input type=file 中的文件,将其赋值给FormData 实例的某个属性,做上传。

HTML:

<div class="test" style="width: 200px;height: 200px; border: 1px solid">
    <input id="image" type="file">
</div>
<button id="upload">上传</button>

JS:

    $("#upload").click(function () {
        var file = $("#image")[0].files[0];
        //打印file 为对象
        console.log(file);

        var formObj = new FormData();
        formObj.set('image', file);
        $.ajax({
            url:'/test/upload',
            data:formObj,
            type: 'POST',
            dataType:'json',
            processData:false,
            contentType:false,
            success:function (res) {

            },
            fail : function (res) {

            }
        });
    });

对应的PHP方法中打印获取的文件信息。

function testFile() {

  print_r($_FILES);

}
/**
Array
(
    [image] => Array
        (
            [name] => red.jpg
            [type] => image/jpeg
            [tmp_name] => /tmp/phpXFXMw5
            [error] => 0
            [size] => 23989
        )
)
**/
VB.NET 和 JavaScript 的 FormData 对象通常用于通过 AJAX 实现文件上传,包括多张图片。以下是使用 jQuery 作为前端库的一个简单示例,说明如何实现这个功能: ```javascript // HTML部分 <input type="file" id="imageFiles" multiple /> <script> $(document).ready(function () { // 获取文件输入元素并监听change事件 $('#imageFiles').on('change', function (e) { var files = e.target.files; // 获取用户选择的文件 if (files.length > 0) { // 如果有选中的文件 var formData = new FormData(); // 创建新的FormData对象 for (var i = 0; i < files.length; i++) { formData.append('images[]', files[i]); // 将每张图片添加到formData } // 发送Ajax请求 $.ajax({ url: 'your-server-url/upload', // 替换为你的服务器上传地址 type: 'POST', data: formData, contentType: false, // 必须设置为false,因为FormData不处理Content-Type processData: false, // 同样是因为FormData不需要处理数据 xhr: function () { // 使用自定义xhr对象处理文件上传 var xhr = new XMLHttpRequest(); xhr.upload.addEventListener('progress', function (event) { if (event.lengthComputable) { var percentComplete = event.loaded / event.total * 100; console.log('Uploading... ' + Math.round(percentComplete) + '%'); } }, false); return xhr; }, success: function (response) { console.log('Upload successful:', response); }, error: function (error) { console.error('Error uploading:', error); } }); } else { console.log('No file selected.'); } }); }); </script> ``` 在这个例子中,前端获取用户的文件选择,然后将每一张图片添加到 `FormData` 中,最后发送一个 POST 请求到指定的服务器 URL。后端接收请求后,需要解析 `FormData` 并处理文件上传。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值