无刷新文件上传 利用iframe实现

效果如图:

示例是基于asp.net mvc实现的

html代码:

<form id="form2" name="form2" class="form-horizontal" enctype="multipart/form-data" action="UploadIcon" method="post" target="ajaxUpload">
    <div class="form-group">
        <label for="inputIcon" class="col-sm-2 control-label">头像</label>
        <div class="col-sm-5">
            <input type="file" id="inputIcon" name="icon" accept="image/*" placeholder="路径" onchange="uploadFile()">
            <iframe name="ajaxUpload" frameborder="0" width="100px" height="100px"></iframe>
        </div>
    </div>
</form>

需要一个页面UploadIcon.cshtml:

@{
    Layout = null;
}

<!DOCTYPE html>

<html>
<head>
    <meta name="viewport" content="width=device-width" />
</head>
<body>
    <img alt="" width="50px" height="50px" src="@ViewData["iconPath"]" />
</body>
</html>

JS代码:

function uploadFile() {
    $('#form2').submit();
}

C#代码:

public ActionResult UploadIcon()
{
    string fileName = Request.Files["icon"].FileName;
    string filePath = "/Data/UserIcon/Temp/" + Guid.NewGuid() + fileName.Substring(fileName.LastIndexOf('.'));
    Request.Files["icon"].SaveAs(Server.MapPath(filePath));
    ViewData["iconPath"] = filePath;
    return View();
}

 

转载于:https://www.cnblogs.com/sydeveloper/p/3678931.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值