Ajax调用MVC控制器参数为实体

15 篇文章 0 订阅

mvc有一个很好的特性,可以把JQ使用Ajax请求的时候,把json解析成为后台的实体类。这里举一个简单的例子。

前台完整代码:

@{
    Layout = null;
}


<!DOCTYPE html>


<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>添加系统用户</title>
    <script src="~/Plugins/Easyui/jquery.min.js"></script>
    <script type="text/javascript">
        function btnAdd_click() {
            var UserPassWord = $('#txtUserPassWord').val();
            var UserPassWord2 = $('#txtUserPassWord2').val();
            if (UserPassWord != UserPassWord2) {
                alert('两次填写的密码必须相同。');
                return;
            }
            var userdata = {
                'UserAccount': $('#txtUserAccount').val(),
                'UserPassWord': $('#txtUserPassWord').val(),
                'UserName': $('#txtUserName').val(),
            }
            $.ajax({
                type: "post",
                url: "/UserManage/AddUser",
                data: userdata,
                dataType: "json",
                success: function (msg) {
                    alert(msg);
                }
            });
        }
    </script>
</head>
<body>
    <div>
        <table>
            <tr>
                <td>登录账号:</td>
                <td>
                    <input type="text" id="txtUserAccount" /></td>
            </tr>
            <tr>
                <td>登录密码:</td>
                <td>
                    <input type="text" id="txtUserPassWord" /></td>
            </tr>
            <tr>
                <td>确认登录密码:</td>
                <td>
                    <input type="text" id="txtUserPassWord2" /></td>
            </tr>
            <tr>
                <td>用户名:</td>
                <td>
                    <input type="text" id="txtUserName" /></td>
            </tr>
            <tr>
                <td colspan="2">
                    <input type="button" id="btnAdd" οnclick="btnAdd_click();" value="添加" /></td>
            </tr>
        </table>
    </div>
</body>
</html>

控制器写法:

        /// <summary>
        /// 添加系统用户
        /// </summary>
        /// <param name="user">系统用户信息</param>
        /// <returns>执行结果</returns>
        public JsonResult AddUser(Entity.SUser user)
        {
            return Json(BLL.UserManage.AddUser(user), JsonRequestBehavior.AllowGet);
        }

实体类:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;


namespace Entity
{
    /// <summary>
    /// 系统用户表
    /// </summary>
    public class SUser
    {
        private int? id;
        /// <summary>
        /// 自增ID
        /// </summary>
        public int? ID
        {
            get { return id; }
            set { id = value; }
        }
        private string userAccount;
        /// <summary>
        /// 用户账号
        /// </summary>
        public string UserAccount
        {
            get { return userAccount; }
            set { userAccount = value; }
        }
        private string userPassWord;
        /// <summary>
        /// 用户密码
        /// </summary>
        public string UserPassWord
        {
            get { return userPassWord; }
            set { userPassWord = value; }
        }
        private string userName;
        /// <summary>
        /// 用户姓名
        /// </summary>
        public string UserName
        {
            get { return userName; }
            set { userName = value; }
        }
    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值