MVC4做网站六后台管理:6.1.4管理员列表、添加及删除_.NET_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > .NET > MVC4做网站六后台管理:6.1.4管理员列表、添加及删除

MVC4做网站六后台管理:6.1.4管理员列表、添加及删除

 2013/11/12 22:45:23  洞庭夕照  博客园  我要评论(0)
  • 摘要:一、管理员列表1、首先【AdministratorController】中添加返回分部视图的publicPartialViewResultIndex()///<summary>///管理员列表///</summary>///<returns></returns>[AdminAuthorize]publicPartialViewResultIndex(){returnPartialView();;}2、在添加publicJsonResultList
  • 标签:MVC 网站

一、管理员列表

1、首先【AdministratorController】中添加返回分部视图的public PartialViewResult Index()

/// <summary>
        /// 管理员列表
        /// </summary>
        /// <returns></returns>
        [AdminAuthorize]
        public PartialViewResult Index()
        {
            return PartialView(); ;
        }

2、在添加public JsonResult List()返回管理员列表数据

/// <summary>
        /// 管理员列表
        /// </summary>
        /// <returns></returns>
        [AdminAuthorize]
        public JsonResult List()
        {
            return Json(adminRsy.Find());
        }

3、为Index()添加局部视图。视图中利用easyui的datagrid进行管理

@Scripts.Render("~/Areas/Admin/Scripts/Administrator.js")
<div class="c_navbar">网站设置 >> 管理员管理</div>
<div id="admin_wapper" class="fs_wapper">
    <div class="header">管理员设置 </div>
    <table id="admin_datagrid" class="easyui-datagrid" data-options="url:'@Url.Action("List", "Administrator")',singleSelect:true,toolbar:'#toolbar'">
        <thead>
            <tr>
                <th data-options="field:'AdministratorId'">ID</th>
                <th data-options="field:'IsPreset'">系统账号</th>
                <th data-options="field:'AdminName'">用户名</th>
                <th data-options="field:'Name'">姓名</th>
                <th data-options="field:'Email'">电子邮件</th>
            </tr>
        </thead>
    </table>
    <div id="toolbar">
        <a href="javascript:void(0)" class="easyui-linkbutton" iconcls="icon-add" plain="true" onclick="AdminAddDlgShow()">添加</a>
        <a href="javascript:void(0)" class="easyui-linkbutton" iconcls="icon-edit" plain="true" onclick="AdminDelRow('@Url.Action("Delete", "Administrator")')">删除</a>
    </div>
    <div id="adminadddlg" class="easyui-dialog" title="添加管理员" style="width:620px;height:290px;" data-options="iconCls:'icon-save',resizable:true,modal:true,closed:true,href:'@Url.Action("Add", "Administrator")'"></div>
</div>

4、管理员添加

首先添加一个显示添加视图的action  public PartialViewResult Add()

/// <summary>
        /// 添加管理员
        /// </summary>
        /// <returns></returns>
        [AdminAuthorize]
        public PartialViewResult Add()
        {
            return PartialView();
        }

再添加一个提交后的处理action public JsonResult Add(Administrator admin)

[AdminAuthorize]
        [HttpPost]
        public JsonResult Add(Administrator admin)
        {
            JsonData _jdata = new JsonData();
            if (ModelState.IsValid)
            {
                if (adminRsy.Find(admin.AdminName) != null)
                {
                    _jdata.Success = false;
                    _jdata.Message = "管理员名称已存在!";
                }
                else
                {
                    admin.IsPreset = false;
                    if (adminRsy.Add(admin))
                    {
                        _jdata.Success = true;
                        _jdata.Message = "保存成功√!";
                    }
                    else
                    {
                        _jdata.Success = false;
                        _jdata.Message = "数据未能保存到数据库!";
                    }
                }
            }
            else
            {
                var _eItem = ModelState.Where(m => m.Value.Errors.Count > 0);//获取验证失败的项
                foreach (var i in _eItem)
                {
                    _jdata.MessageLsit.Add(i.Key, "验证失败!");
                }
            }
            return Json(_jdata);
        }

为Add()添加局部视图

@model Ninesky.Areas.Admin.Models.Administrator
<div class="fs_wapper">
    @using (Html.BeginForm("Add", "Administrator", FormMethod.Post, new { id = "adminadd_form" }))
    {
        @Html.AntiForgeryToken()
        @Html.ValidationSummary()
        <table>
            <tr>
                <th>@Html.LabelFor(model => model.AdminName)</th>
                <td>@Html.EasyuiInput(model => model.AdminName, new { @class = "easyui-validatebox" })
                    @Html.DisplayDescriptionFor(model => model.AdminName)</td>
            </tr>
            <tr>
                <th>@Html.LabelFor(model => model.PassWord)</th>
                <td>@Html.EasyuiInput(model => model.PassWord, new { @class = "easyui-validatebox",type="password" })
                    @Html.DisplayDescriptionFor(model => model.PassWord)</td>
            </tr>
            <tr>
                <th>@Html.LabelFor(model => model.Name)</th>
                <td>@Html.EasyuiInput(model => model.Name, new { @class = "easyui-validatebox" })
                    @Html.DisplayDescriptionFor(model => model.Name)</td>
            </tr>
            <tr>
                <th>@Html.LabelFor(model => model.Email)</th>
                <td>@Html.EasyuiInput(model => model.Email, new { @class = "easyui-validatebox" })
                    @Html.DisplayDescriptionFor(model => model.Email)</td>
            </tr>
        </table> 
    }
</div>
<div style="margin:20px;">
    <a href="javascript:void(0)" class="easyui-linkbutton" iconcls="icon-ok" onclick="AdminAddSave()">保存</a>
    <a href="javascript:void(0)" class="easyui-linkbutton" iconcls="icon-cancel" onclick="AdminAddDlgClose()">关闭</a>
</div>

打开Administrator.js 写点击保存和点击关闭的js函数

//添加管理员保存
function AdminAddSave() {
    
    $('#adminadd_form').form('submit', {
        success: function (data) {
            var rt = jQuery.parseJSON(data);
            if (rt.Success) {
                $.messager.alert("保存成功", rt.Message,"" ,function () {
                    $("#adminadddlg").dialog("close");
                    $('#admin_datagrid').datagrid("reload");
                });
            }
            else {
                var msg = "";
                if (rt.MessageLsit != undefined) {
                    $.each(rt.MessageLsit, function (i, val) {
                        msg += "<li>" + i + ":" + val + "</li>";
                    });
                }
                if (msg != "") msg = rt.Message + "<br /> <p> 原因如下:" + "<ul>" + msg + "</ul></p>";
                else msg = rt.Message;
                $.messager.alert("保存失败", msg, "error");
            }
        }
    });
}

//关闭添加管理员窗口
function AdminAddDlgClose() {
    $("#adminadddlg").dialog("close");
}

再添加一个显示添加管理员窗口的方法

//显示添加对话框
function AdminAddDlgShow()
{
    $("#adminadddlg").dialog("open");
    $("#adminadddlg").dialog("refresh");
}

image

5、删除管理员

在控制器添加public JsonResult Delete(int Id)

 

/// <summary>
        /// 删除管理员
        /// </summary>
        /// <param name="Id">管理员Id</param>
        /// <returns></returns>
        [AdminAuthorize]
        [HttpPost]
        public JsonResult Delete(int Id)
        {
            JsonData _jdata = new JsonData();
            var _admin = adminRsy.Find(Id);
            if (_admin == null)
            {
                _jdata.Success = false;
                _jdata.Message = "Id为: " + Id + " 的管理员不存在!";
            }
            else if (_admin.IsPreset)
            {
                _jdata.Success = false;
                _jdata.Message = "不能删除系统预置管理员账号!";
            }
            else
            {
                if (adminRsy.Delete(Id))
                {
                    _jdata.Success = true;
                    _jdata.Message = "删除成功√";
                }
                else
                {
                    _jdata.Success = false;
                    _jdata.Message = "删除失败!";
                }
            }
            return Json(_jdata);

        }

在Administrator.js 中增加 删除管理员的客户端js方法

//删除管理员
function AdminDelRow(url) {
    var row = $('#admin_datagrid').datagrid('getSelected');
    if (row) {
        $.messager.confirm('确认', '你确定要删除此管理员', function (r) {
            if (r) {
                $.post(url, { Id: row.AdministratorId }, function (data) {
                    if (data.Success) {
                        $.messager.alert("删除成功", data.Msg, "", function () { $("#admin_datagrid").datagrid("reload"); });
                    }
                    else $.messager.alert("错误", data.Msg, "error");
                });
            }
        });
    }
}

大功告成!

image

代码http://pan.baidu.com/s/1rG1vH

发表评论
用户名: 匿名