异步上传图片的几种方式

使用jquery.form.js插件实现

  1. HTML页面
<!DOCTYPE html>
<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Index</title>
    <script src="~/Scripts/jquery-3.3.1.js"></script>
    <script src="~/Scripts/jquery.form.js"></script>
</head>
<body>
    <form enctype="multipart/form-data" method="post" id="upload">
        <input type="file" id="fileupload" name="Upload" />
        <input type="button" value="上传图片" id="btn">
        <div id="resultDiv"></div>
    </form>
    <script>
        $("#btn").click(function () {
            $("#upload").ajaxSubmit({
                url: "../Home/UploadFile",
                type: "post",
                success: function (data) {
                    $("#resultDiv").html("<img src='" + data._data._url + "' />");
                },
                error: function (error) {
                    console.log(error);
                }
            });
            return false;
        });
    </script>
</body>
</html>
  1. 控制器(Controller)
public class HomeController : Controller
    {
        // GET: Home
        public ActionResult Index()
        {
            return View();
        }

        [HttpPost]
        public JsonResult UploadFile()
        {
            HttpPostedFileBase file = Request.Files[0];
            if (file != null)
            {
                string fileName = Path.GetFileName(file.FileName);
                string fileExt = Path.GetExtension(file.FileName);
                string fileNewName = Guid.NewGuid() + fileExt;
                string fileSaveDir = Server.MapPath("~/upload");
                if (!Directory.Exists(fileSaveDir))
                {
                    Directory.CreateDirectory(fileSaveDir);
                }
                file.SaveAs(Path.Combine(fileSaveDir, fileName));
                return new JsonResult
                {
                    Data = new
                    {
                        _code = 200,
                        _msg = "上传成功",
                        _data = new
                        {
                            _url = "/Upload/" + fileName,
                            _oldName = fileName
                        }
                    }
                    ,
                    JsonRequestBehavior = JsonRequestBehavior.DenyGet
                };
            }
            return new JsonResult
            {
                Data = new
                {
                    _code = 200,
                    _msg = "上传失败"
                },
                JsonRequestBehavior = JsonRequestBehavior.DenyGet
            };
        }
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
form 表单的提交有以下几种方式: 1. GET 方法提交:当表单的 `method` 属性设置为 `GET` 时,表单数据会附加在 URL 的查询参数中,通过 GET 请求发送给服务器。这种方式适用于对数据安全性要求不高、数据量较小的情况,例如搜索表单。 2. POST 方法提交:当表单的 `method` 属性设置为 `POST` 时,表单数据会作为请求的内容体发送给服务器。这种方式适用于传输敏感数据或者数据量较大的情况,例如用户注册或登录表单。 3. AJAX 提交:使用 JavaScript 的 XMLHttpRequest 或 Fetch API,可以通过异步方式将表单数据发送给服务器。这种方式可以在不刷新整个页面的情况下发送数据,并且可以处理服务器返回的结果,实现无刷新的交互效果。 4. File Upload 提交:当表单包含文件上传字段时,可以使用特殊的 enctype 属性(如 `enctype="multipart/form-data"`)以及相应的后端处理逻辑来实现文件的上传。这种方式适用于需要上传文件的场景,例如上传图片、视频等。 5. 使用 JavaScript 提交:通过 JavaScript 可以监听表单的提交事件,并自定义处理逻辑。可以使用 JavaScript 构建请求并将表单数据发送给服务器,例如使用 Fetch API 或其他 AJAX 库来完成提交操作。 需要注意的是,在表单提交时,通常会通过设置 `action` 属性指定处理表单数据的后端地址。同时,表单字段需要通过 `name` 属性来标识,以便后端能够正确解析和处理数据。 根据具体的需求和场景,可以选择适合的提交方式来实现表单数据的传输和处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

何兮&

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值