利用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
        )
)
**/
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值