四种Post请求提交数据的方法

HTML布局如下:

  <div class="container mt-5">
        <form id="myform" @*method="get" action="~/From/getData"*@>
            <div class="form-group form-row">
                <label class="col-form-label col-3 text-center">姓名</label>
                <input class="form-control col-9" type="text" name="name" id="txtName" />
            </div>
            <div class="form-group form-row">
                <label class="col-form-label col-3 text-center">性别</label>
                <select class="form-control col-9" name="sex" id="cboSex">
                    <option value="0">--请选择--</option>
                    <option value=""></option>
                    <option value=""></option>
                </select>
            </div> 
            <div class="form-group form-row">
                <label class="col-form-label col-3 text-center">地址</label>
                <textarea class="form-control col-9" name="address" id="txtAddress"></textarea>
            </div>
            <div class="form-group form-row">
                <button type="submit" class="btn btn-outline-primary offset-3 mr-2">表单提交</button>
                <button type="button" class="btn btn-outline-success mr-2" onclick="getData()">GET提交</button>
                <button type="button" class="btn btn-outline-success mr-2" onclick="postData()">POST提交</button>
                <button type="reset" class="btn btn-outline-danger">Reset重置</button>
            </div>
        </form>
    </div>

Javascript代码如下:

 function getData() {
            var name = document.getElementById("txtName").value;
            var sex = document.getElementById("cboSex").value;
            var address = document.getElementById("txtAddress").value;
            if (name == "" || sex == 0 || address == "") {
                alert("数据不完整");
            } else {
                var myform = document.getElementById("myform");
                myform.method = "get";
                myform.action = "/From/getDataEntityClass";
                myform.submit();
            }
        }
        function postData() {
            var name = document.getElementById("txtName").value;
            var sex = document.getElementById("cboSex").value;
            var address = document.getElementById("txtAddress").value;
            if (name == "" || sex == 0 || address == "") {
                alert("数据不完整");
            } else {
                var myform = document.getElementById("myform");
                myform.method = "post";//提交的方式
                myform.action = "/From/getDataRequest"; //数据提交的方法
                myform.submit();
            }
        }

效果图如下:
在这里插入图片描述
在这里插入图片描述
第一种:通过形参的方式接收表单提交的数据

public ActionResult getData(string name,string sex,string address)
        {
            string str = name + sex + address;
            return Content(str+"成功接收到数据");
        }

第二种:通过FormCollection来接收表单的数据

public ActionResult getDataFormCollection(FormCollection form)
        {
            string name = form["name"];
            string sex = form["sex"];
            string address = form["address"];
            string str = name + "&" + sex + "&" + address + "&" + "FormCollection只接收post数据";
            return Content(str);
        }

第三种:通过 Request.Form[“name的属性值”]获取表单数据

public ActionResult getDataRequest()
        {
            string name = Request.Form["name"];
            string sex = Request.Form["sex"];
         string address = Request.Form["address"];
         string str = name + "&" + sex + "&" + address + "&" + "Request只接收post数据";
            return Content(str);
        }

第四种:EntityClass实体类接收数据

public ActionResult getDataEntityClass(Person entityClass)
        {
            string name = entityClass.name;
            string sex = entityClass.sex;
            string address = entityClass.sex;
            string str = name + "&" + sex + "&" + address + "&" + "EntityClass是实体类数据,可以接收post和get数据";
            return Content(str);
        }
        public class Person{
        public string name { get; set; }
        public string sex { get; set; }
        public string address { get; set; }
        }

我们可以通过myform.action = ""使用其他的方法
myform.action = "/From/ getData ";
myform.action = "/From/ getDataFormCollection ";
myform.action = "/From/ getDataRequest ";
myform.action = "/From/ getDataEntityClass ";

  • 11
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值