使用Jquery+EasyUI 进行框架项目开发案例讲解之三---角色管理源码分享

简介:

  我们分享了使用Jquery EasyUI来进行UI布局等开发的相关方法,也许你在使用EasyUI的过程过更熟练,有更方便快捷的技巧,我强烈建议你可以分享出来,大家共同进步、共同学习,谢谢!

  接下来我分享“角色管理”模块主要的核心代码,角色管理主界面如下图所示:

11140334-a11ba488e0e34937aa057cc96c3e276

  首先是角色管理的UI界面aspx代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
<%@ Page Language="C#" MasterPageFile="~/Site.Master" AutoEventWireup="true" CodeBehind="RoleAdmin.aspx.cs" Inherits="RDIFramework.WebApp.Modules.RoleAdmin" %>
< asp:Content  ID = "Content1"  ContentPlaceHolderID = "head"  runat = "server" >
< script  src = "../Scripts/jquery-checkbox.js"  type = "text/javascript" ></ script >
< script  src = "../Scripts/jQuery.Select.js"  type = "text/javascript" ></ script >
< script  src = "../Scripts/jquery.easyListSplitter.js"  type = "text/javascript" ></ script >
< script  src = "../Scripts/Business/RoleAdmin.js"  type = "text/javascript" ></ script >
</ asp:Content >
< asp:Content  ID = "Content2"  ContentPlaceHolderID = "ContentPlaceHolder1"  runat = "server" >
< div  class = "toolbar" >
     <%=base.BuildToolBarButtons() %> &nbsp;&nbsp;角色分类:&nbsp; < input  id = "txtCategory"  name = Category  type = "text"  style = "width:200px"  class = "txt03"  />&nbsp;&nbsp;< a  id = "a_search"  class = "easyui-linkbutton"  plain = "true"  icon = "icon-search" >查询</ a >
</ div >
< div  id = "scolldiv"  style = "width:100%;overflow:auto;" >
     < input  id = "hidrolecategory"  type = "hidden"  value = ""  runat = "server"  />
  < asp:GridView  ID = "gvRoleList"  runat = "server"  AutoGenerateColumns = "False"  CssClass = "grid2"  Width = "100%" >
         < Columns >      
         < asp:TemplateField  ItemStyle-Width = "1px"   ItemStyle-HorizontalAlign = "Center" >
             < ItemTemplate >
                 < input  type = "hidden"  value = "<%#Eval(" Id") %>" />             
             </ ItemTemplate >
         </ asp:TemplateField >
         <%--< asp:TemplateField  ItemStyle-Width = "20px"   ItemStyle-HorizontalAlign = "Center"  >          
             < ItemTemplate >              
                 <%#Container.DataItemIndex+1 %>              
             </ ItemTemplate >      
         </ asp:TemplateField >  --%>
             < asp:BoundField  DataField = "Code"  HeaderText = "角色编号"  ItemStyle-Width  "120px" />         
             < asp:BoundField  DataField = "RealName"  HeaderText = "角色名称"   ItemStyle-Width  "150px" />          
             < asp:BoundField  DataField = "Enabled"  HeaderText = "有效"  ItemStyle-Width  "80px" />        
             < asp:BoundField  DataField = "Description"  HeaderText = "描述" />
             < asp:TemplateField  HeaderText = "管理"  ItemStyle-Width = "320px"  ItemStyle-HorizontalAlign = "Center" >
                 < ItemTemplate >
                     < a  href = "#"  rel = "edit"  rid = "<%#Eval(" Id")%>"  <%if(!permissionEdit) {Response.Write("disabled");}%>   roleCategory ="<%#Eval("Category") %>" title="编辑当前角色">< span  class = "icon icon-group_edit" >&nbsp;</ span >[修改]</ a >&nbsp;
                     < a  style = "cursor: pointer;"  rel = "delete"   rid = "<%#Eval(" Id") %>"  <%if(permissionDelete != true) {Response.Write("disabled");}%>   title="删除当前角色"  >< span  class = "icon icon-group_delete" >&nbsp;</ span >[删除]</ a >&nbsp;
                     < a  style = "cursor: pointer;"  rel = "setuser"   rid = "<%#Eval(" Id") %>"  <%if(!permissionRoleUser) {Response.Write("disabled");}%>   title="设置当前角色所拥有的用户">< span  class = "icon icon-group_link" >&nbsp;</ span >[用户]</ a >
                 </ ItemTemplate >
             </ asp:TemplateField >
         </ Columns >
     </ asp:GridView >
</ div >
< div  id = "w" ></ div >< div  id = "d" ></ div >
< script  type = "text/javascript" >
     $(document).ready(function () {
         // 浏览器的高度和div的高度
         var height = $(window).height();
         var divHeight = $("#scolldiv").height();
         //获取div对象
         var divh = $("#scolldiv").get(0);
         //div高度大于屏幕高度把屏幕高度赋给div,并出现滚动条
         if (divHeight > height - 40) {
             divh.style.height = height - 40;
             divh.style.overflow = "auto";
         }
         $('#txtCategory').combobox({
             url: 'handler/DataItemAdminHandler.ashx?action=GetCategory&categorycode=RoleCategory',
             method: 'get',
             valueField: 'ItemValue',
             textField: 'ItemName',
             editable: false,
             panelHeight: 'auto'
         });
     });
</ script >
</ asp:Content >


绑定当前登录用户所拥有的功能按钮列表代码如下: 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
/// <summary>
/// 获得页面的权限
/// </summary>
private  void  GetPermission()
{         
     this .permissionAdd =  this .IsAuthorized( "RoleManagement.Add" );
     this .permissionEdit =  this .IsAuthorized( "RoleManagement.Edit" );
     this .permissionExport =  this .IsAuthorized( "RoleManagement.Export" );
     this .permissionDelete =  this .IsAuthorized( "RoleManagement.Delete" );
     this .permissionRoleUser =  this .IsAuthorized( "RoleManagement.RoleUser" );
}
/// <summary>
/// 加载工具栏
/// </summary>
/// <returns>工具栏HTML</returns>
public  override  string  BuildToolBarButtons()
{
     StringBuilder sb =  new  StringBuilder();
     string  linkbtn_template =  "<a id=\"a_{0}\" class=\"easyui-linkbutton\" style=\"float:left\"  plain=\"true\" href=\"javascript:;\" icon=\"{1}\"  {2} title=\"{3}\">{4}</a>" ;
     sb.Append( "<a id=\"a_refresh\" class=\"easyui-linkbutton\" style=\"float:left\"  plain=\"true\" href=\"javascript:;\" icon=\"icon-reload\"  title=\"重新加载\">刷新</a> " );
     sb.Append( "<div class='datagrid-btn-separator'></div> " );
     sb.Append( string .Format(linkbtn_template,  "add" "icon-group-add" , permissionAdd ?  ""  "disabled=\"True\"" "新增角色" "新增" ));
     sb.Append( string .Format(linkbtn_template,  "edit" "icon-group_edit" , permissionEdit ?  ""  "disabled=\"True\"" "修改选中角色" "修改" ));
     sb.Append( string .Format(linkbtn_template,  "del" "icon-group_delete" , permissionDelete ?  ""  "disabled=\"True\"" "删除选中角色" "删除" ));
     sb.Append( "<div class='datagrid-btn-separator'></div> " );
     sb.Append( string .Format(linkbtn_template,  "roleuser" "icon-group_link" , permissionRoleUser ?  ""  "disabled=\"True\"" "设置当前角色拥有的用户" "用户" ));
     return  sb.ToString();
}
private  void  InitGrid()
{  
     this .DTRole =  base .GetRoleScope( this .PermissionItemCode);
     this .gvRoleList.DataSource =  this .DTRole;
     this .gvRoleList.DataBind();
}

  核心业务逻辑完整JS代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
$( function  () {
     addRole();
     editRole();
     delRole();
     $( '#a_edit' ).click( function  () {
         if  ($( this ).linkbutton( 'options' ).disabled ==  true ) {
             return ;
         }
         var  i = $( 'table' ).data( 'tr_index' );
         if  (i > -1)
             $( '.grid2 tr' ).eq(i).find( "a[rel='edit']" ).click();
         else
             top.$( '#notity' ).jnotifyAddMessage({ text:  '请选择要编辑的数据.' , permanent:  false , type:  'warning'  });
     });
     $( '#a_del' ).click( function  () {
         if  ($( this ).linkbutton( 'options' ).disabled ==  true ) {
             return ;
         }
         var  i = $( 'table' ).data( 'tr_index' );
         if  (i > -1)
             $( '.grid2 tr' ).eq(i).find( "a[rel='delete']" ).click();
         else
             top.$( '#notity' ).jnotifyAddMessage({ text:  '请选择要删除的数据.' , permanent:  false , type:  'warning'  });
     });
     $( '#a_roleuser' ).click( function  () {
         if  ($( this ).linkbutton( 'options' ).disabled ==  true ) {
             return ;
         }
         var  i = $( 'table' ).data( 'tr_index' );
         if  (i > -1)
             $( '.grid2 tr' ).eq(i).find( "a[rel='setuser']" ).click();
         else
             top.$( '#notity' ).jnotifyAddMessage({ text:  '请选择要添加用户的角色.' , permanent:  false , type:  'warning'  });
     });
     $( '#a_refresh' ).click( function  () {
         window.location =  'RoleAdmin.aspx' ;
     });
     using( 'linkbutton' function  () {
         $( '#a_roleuser' ).linkbutton({ text:  "成员"  });
     });
     accreditUsers();  //授权角色包含的用户
     searchUser();
     $( '#txtCategory' ).combobox({
         onChange:  function  (newValue, oldValue) {
             $( "#hidrolecategory" ).val(newValue)
         }
     })
});
function  scripthtmlStr() {
     var  html =  '<form id="uiform"><table cellpadding=5 cellspacing=0 width=100% align="center" class="grid" border=0><tr><td align="right">'
     html +=  '角色编号:</td><td align="left"><input id="txtCode"  name=Code type="text"  required="true" style="width:280px" class="txt03"/></td></tr><tr><td align="right">' ;
     html +=  '角色名称:</td><td align="left"><input id="txtRealName"  name=RealName type="text"  required="true" style="width:280px" class="txt03"/></td></tr><tr><td align="right">' ;
     html +=  '角色分类:</td><td align="left"><input id="txtCategory" name=Category type="text"  required="true" style="width:280px" class="txt03" /></td></tr><tr><td align="right">' ;
     html +=  '有效性:</td><td align="left"><input id="chkEnabled" type="checkbox" name="Enabled" /><label>有效</label>&nbsp;&nbsp;<span style="color:#666;padding-left:20px;">注:选中则启用该角色。</span></td></tr><tr><td align="right"> ' ;
     html +=  '角色描述:</td><td align="left"><textarea rows="3" id="txtDescription"  name=Description style="width:280px;height:50px;" class="txt03"/></td></tr>' ;
     html +=  '</table></form>' ;
     return  html;
}
function  searchUser() {
     $( '#a_search' ).click( function  () {
         var  vValue = $( '#txtCategory' ).combobox( 'getValue' ) +  '|'  + $( '#txtCategory' ).combobox( 'getText' );
         top.$( '#notity' ).jnotifyAddMessage({ text: vValue, permanent:  false  });
     });
}
function  addRole() {
     $( '#a_add' ).click( function  () {
         if  ($( this ).linkbutton( 'options' ).disabled ==  true ) {
             return ;
         }
         top.$( '#w' ).hWindow({ title:  '新增角色' , iconCls:  'icon-group-add' , width: 450, height: 320, html: scripthtmlStr(), submit:  function  () {
             top.$( '#txtCode' ).validatebox();
             top.$( '#txtRealName' ).validatebox();
             top.$( '#txtCategory' ).validatebox();
             var  $txtrolecode = top.$( '#txtCode' );
             var  $txtrolename = top.$( '#txtRealName' );
             var  enabledSelected = top.$( "#chkEnabled" ).attr( "checked" );
             var  $txtdescription = top.$( '#txtDescription' );
             var  vcategory = top.$( '#txtCategory' ).combobox( 'getValue' );
             if  ($txtrolename.val() !=  '' ) {
                 $.ajaxtext( 'handler/RoleAdminHandler.ashx?t='  + Math.random(),  'action=add&rolecode='  + $txtrolecode.val() +  '&rolename='  + $txtrolename.val() +  '&category='  + vcategory +  '&enabled='  + enabledSelected +  '&description='  + $txtdescription.val(),  function  (msg) {
                     if  (msg ==  '1' ) {
                         top.$( '#notity' ).jnotifyAddMessage({ text:  '新增角色成功。' , permanent:  false  });
                         top.$( '#w' ).window( 'close' );
                         window.location =  'RoleAdmin.aspx' ;
                     else  {
                         alert(msg);
                         return  false ;
                     }
                 })
             else  {
                 top.$( '#notity' ).jnotifyAddMessage({ text:  '请输入角色名称.' , permanent:  false  });
                 top.$( '#txtRealName' ).focus();
             }
             return  false ;
         }
         });
         bindCategory();
         top.$( '#txtCode' ).focus();
         top.$( '#chkEnabled' ).attr( "checked" true );
     });
}
function  editRole() {
     $( "a[rel='edit']" ).click( function  () {
         if  ($( '#a_edit' ).linkbutton( 'options' ).disabled ==  true ) {
             return ;
         }
         var  id = $( this ).attr( 'rid' );
         var  roleCategory = $( this ).attr( 'roleCategory' );
         var  tds = $( this ).parent().siblings();
         top.$( '#w' ).hWindow({ title:  '编辑角色信息' , iconCls:  'icon-group_edit' , width: 450, height: 320, html: scripthtmlStr(), submit:  function  () {
             var  $txtrolecode = top.$( '#txtCode' );
             var  $txtrealname = top.$( '#txtRealName' );
             var  enabledSelected = top.$( "#chkEnabled" ).attr( "checked" );
             var  $txtdescription = top.$( '#txtDescription' );
             var  vcategory = top.$( '#txtCategory' ).combobox( 'getValue' );
             if  ($txtrealname.validatebox( 'isValid' )) {
                 $.ajaxtext( 'handler/RoleAdminHandler.ashx?n='  + Math.random(),  'action=edit&rolecode='  + $txtrolecode.val() +  '&rolename='  + $txtrealname.val() +  '&category='  + vcategory +  '&enabled='  + enabledSelected +  '&description='  + $.trim($txtdescription.val()) +  '&roleid='  + id,
                 function  (msg) {
                     if  (msg ==  '1' ) {
                         top.$( '#notity' ).jnotifyAddMessage({ text:  '角色信息修改成功.' , permanent:  false  });
                         top.$( '#w' ).window( 'close' );
                         window.location =  'RoleAdmin.aspx' ;
                     else  {
                         alert(msg);
                         return  false ;
                     }
                 })
             }
         }
         });
         top.$( '#txtRealName' ).validatebox();
         top.$( '#txtCode' ).val(tds.eq(1).html().replace( '&nbsp;' '' ));
         top.$( '#txtRealName' ).val(tds.eq(2).html().replace( '&nbsp;' '' ));
         //top.$('#txtCategory').val(roleCategory);
         top.$( '#chkEnabled' ).attr( "checked" , tds.eq(3).html().replace( '&nbsp;' '' ) ==  "1" );
         top.$( '#txtDescription' ).val(tds.eq(4).html().replace( '&nbsp;' '' ));
         bindCategory();
         top.$( '#txtCategory' ).combobox( "setValue" , roleCategory);
     })
}
function  delRole() {
     $( "a[rel='delete']" ).click( function  () {
         if  ($( '#a_del' ).linkbutton( 'options' ).disabled ==  true ) {
             return ;
         }
         var  rid = $( this ).attr( 'rid' );
         if  (rid !=  '' ) {
             $.messager.confirm( '询问提示' '你确认删除当前所选角色吗?' function  (data) {
              if  (data) {  
                     $.ajax({
                         type:  'post' ,
                         url:  'handler/RoleAdminHandler.ashx?t=<%=Guid.NewGuid().ToString() %>' ,
                         data:  'action=delete&roleid='  + rid,
                         beforeSend:  function  () { $.showLoading(); },
                         complete:  function  () { $.hideLoading(); },
                         success:  function  (msg) {
                             if  (msg ==  '1' ) {
                                 top.$( '#notity' ).jnotifyAddMessage({ text:  '角色删除成功.' , permanent:  false  });
                                 window.location =  'RoleAdmin.aspx' ;
                             }
                             else
                                 top.$( '#notity' ).jnotifyAddMessage({ text:  '角色删除失败.' , permanent:  false , type:  'warning'  });
                         }
                     });
                 }
             });
                                
         }
         else  {
             top.$( '#notity' ).jnotifyAddMessage({ text:  '请选择要删除的角色。' , permanent:  false , type:  'warning'  });
         }
     });
}
function  bindCategory() {
     top.$( '#txtCategory' ).combobox({
         url:  'Modules/handler/DataItemAdminHandler.ashx?action=GetCategory&categorycode=RoleCategory' ,
         method:  'get' ,
         valueField:  'ItemValue' ,
         textField:  'ItemName' ,
         editable:  false ,
         panelHeight:  'auto'
     });
}
var  formHtml =  '<div style="border-bottom:1px solid #CCC; margin-bottom:5px;"><span id="role_name" class="icon32 icon-group32" style="padding-left:48px;font-weight:bold; font-size:14px;color:#666;">角色名称</span> </div>' ;
     formHtml +=  '<div style=" margin-bottom:10px;">描述:<input id="txtroleremark" type="text" readonly=true class="txt02" style="width:400px;color:#666;"></div>' ;
     formHtml +=  '<div> 成员:</div>' ;
     formHtml +=  '<select id="user_groups" size="10" style="width:475px; line-height:30px;height:195px;padding:5px"></select>' ;
     formHtml +=  '<div style="margin-top:2px;"><a href="#" id="group_add" class="easyui-linkbutton" plain="true" iconCls="icon-group-add">添加</a>' ;
     formHtml +=  '<a href="#" class="easyui-linkbutton" id="group_delete" plain="true" iconCls="icon-group-delete">移除</a>' ;
     formHtml +=  '<a href="#" class="easyui-linkbutton" id="group_clear" plain="true" iconCls="icon-clear">清空</a></div>'
var  userList =  '<table id="sp" cellpadding=5 cellspacing=0 width=100% align="center" ><tr><td><ul class="ul_users checkbox"></ul></td></tr></table><p><input type="checkbox" id="chkall" ><label id="labchkall" for="chkall"><b>全选</b></label></p>' ;
//授权用户
function  accreditUsers() { 
     $( "a[rel='setuser']" ).click( function  () {
         if  ($( '#a_roleuser' ).linkbutton( 'options' ).disabled ==  true ) {
             return ;
         }
         var  i = $( 'table' ).data( 'tr_index' );
         if  (i == undefined) {
             top.$( '#notity' ).jnotifyAddMessage({ text:  '请选择角色.' , permanent:  false , type:  'warning'  });
             return  false ;
         }
         var  tds = $( '.grid2 tr:eq('  + i +  ') td' );
         var  rid = tds.eq(0).find( ':hidden' ).val();  //rid = $(this).attr('rid');
         top.$( '#w' ).hWindow({ html: formHtml, width: 500, height: 400, title:  '角色用户' , iconCls:  'icon-group_link' , submit:  function  () {
             var  users =  new  Array();
             var  count = top.$( '#user_groups' ).get(0).options.length;
             for  ( var  i = 0; i < count; i++) {
                 users.push(top.$( '#user_groups' ).get(0).options[i].value);
             }
             $.ajaxtext( 'handler/RoleAdminHandler.ashx' 'action=setusers&users='  + users +  '&roleid='  + rid,  function  (msg) {
                 if  (msg ==  "1" ) {
                     top.$( '#notity' ).jnotifyAddMessage({ text:  '设置成功。' , permanent:  false , type:  'message'  });
                 }
                 else
                     alert(msg);
                 top.$( '#w' ).window( 'close' );
             });
             return  false ;
         }
         });
         top.$( 'a.easyui-linkbutton' ).linkbutton({ disabled:  false  });
         top.$( '#role_name' ).text(tds.eq(2).text());
         top.$( '#txtroleremark' ).val(tds.eq(4).text());
         $.getJSON( 'handler/RoleAdminHandler.ashx?n='  + Math.random(),  '&action=usersinrole&roleid='  + rid,  function  (json) {
             $.each(json,  function  (i, n) {
                 top.$( '#user_groups' ).append( '<option value="'  + n.Id +  '">'  + n.UserName +  ' | '  + n.RealName +  '</option>' );
             });
         });
         top.$( '#group_add' ).click( function  () {
             top.$( '#d' ).hDialog({ html: userList, title:  '选取用户' , iconCls:  'icon-users' , width: 800, height: 600,
                 submit:  function  () {
                     var  selectedUids =  '' ;
                     top.$( '#sp :checked' ).each( function  () {  //匹配所有sp中被选中的元素(checkbox中被选中的)
                         if  (top.$( this ).is( ':checked' ))
                             selectedUids += top.$( this ).val() +  ',' ;
                     });
                     if  (selectedUids !=  '' )
                         selectedUids = selectedUids.substr(0, selectedUids.length - 1);
                     if  (selectedUids.length == 0) {
                         $.messager.alert( '请至少选择一个用户!' , msg,  'warning' );
                         return  false ;
                     else  {
                         var  users = top.$( '#sp' ).data( 'allusers' );
                         var  selarr = getSelectedUsers(users, selectedUids);
                         top.$( '#user_groups' ).empty();
                         top.$( '#sp' ).removeData( 'allusers' );
                         $.each(selarr,  function  (i, n) {
                             top.$( '#user_groups' ).append( '<option value="'  + n.Id +  '">'  + n.UserName +  ' | '  + n.RealName +  '</option>' );
                         });
                         top.$( '#d' ).dialog( "close" );
                     }
                 }
             });
             var  lis =  '' ;
             $.getJSON( 'handler/UserAdminHandler.ashx?n='  + Math.random(),  '' function  (json) {
                 $.each(json,  function  (i, n) {
                     lis +=  '<li><input type="checkbox" value="'  + n.Id +  '" /><label>'  + n.UserName +  ' | '  + n.RealName +  '</label></li>' ;
                 });
                 top.$( '.ul_users' ).empty().append(lis);
                 top.$( '#sp' ).data( 'allusers' , json);
             });
             top.$( '#labchkall' ).click( function  () {
                 var  flag = $( this ).prev().is( ':checked' );
                 var  pers = $( this ).parent().parent().prev();
                 if  (!flag) {
                     top.$( ":checkbox" '#sp' ).attr( "checked" true );
                 }
                 else  {
                     top.$( ":checkbox" '#sp' ).attr( "checked" false );
                 }
             });
         });
         top.$( '#group_delete' ).click( function  () {
             var  i = top.$( '#user_groups' ).get(0).selectedIndex;
             if  (i > -1) {
                 var  uid = top.$( '#user_groups option:selected' ).val();  //选中的值或 top.$("#user_groups").find("option:selected").val();
                 var  uname = top.$( '#user_groups option:selected' ).text();  //选中的文本 或top.$("#user_groups").find("option:selected").text();
                 top.$( '#user_groups' ).get(0).remove(i);
                 $.ajaxtext( 'handler/RoleAdminHandler.ashx' 'action=removeuserfromrole&uid='  + uid +  '&roleid='  + rid,  function  (msg) {
                     if  (msg ==  "1" ) {
                         top.$( '#notity' ).jnotifyAddMessage({ text:  '移除成功。' , permanent:  false , type:  'message'  });
                     }
                     else  {
                         top.$.messager.alert( '提示信息' , msg,  'warning' );
                     }
                 });
             }
             else  {
                 top.$.messager.alert( "操作提示" "请选择要移除的用户!" "info" );
             }
         });
         top.$( '#group_clear' ).click( function  () {
//            var count = $("#user_groups option").length
//            if (count <= 0) {
//                top.$.messager.alert("操作提示", "当前角色没有用户!", "info");
//                return;
//            }
             top.$.messager.confirm( '询问提示' '确认要清除所有用户吗?' function  (data) {
                 if  (data) {
                     top.$( '#user_groups' ).empty();
                 }
             });
             return  false ;
         });
     });
}
function  getSelectedUsers(users, selecedVals) {
     var  arrUserid = eval( '['  + selecedVals +  ']' );
     var  arr =  new  Array();
     $.each(users,  function  (i, n) {
         if  ($.inArray(n.Id, arrUserid) > -1)
             arr.push(n);
     });
     return  arr;
}


  角色添加界面如下:

10164701-d2a7ce7e4aa64cb0a92588d45122597



角色修改界面:

10164712-a7fd8b6d948246d1ab9128c8b22d7e2


角色用户设置界面:

10164721-d715dee57f284b3484714f28bbb06c6


在上图中,我们可以添加、移除、清空当前角色包含的用户。

   选择添加,打开“选取用户”窗口,如下图所示:

10164736-6cd6b1fa407542b7a37294f728a64a8

角色用户设置及用户选择界面JS代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
var  formHtml =  '<div style="border-bottom:1px solid #CCC; margin-bottom:5px;"><span id="role_name" class="icon32 icon-group32" style="padding-left:48px;font-weight:bold; font-size:14px;color:#666;">角色名称</span> </div>' ;
     formHtml +=  '<div style=" margin-bottom:10px;">描述:<input id="txtroleremark" type="text" readonly=true class="txt02" style="width:400px;color:#666;"></div>' ;
     formHtml +=  '<div> 成员:</div>' ;
     formHtml +=  '<select id="user_groups" size="10" style="width:475px; line-height:30px;height:195px;padding:5px"></select>' ;
     formHtml +=  '<div style="margin-top:2px;"><a href="#" id="group_add" class="easyui-linkbutton" plain="true" iconCls="icon-group-add">添加</a>' ;
     formHtml +=  '<a href="#" class="easyui-linkbutton" id="group_delete" plain="true" iconCls="icon-group-delete">移除</a>' ;
     formHtml +=  '<a href="#" class="easyui-linkbutton" id="group_clear" plain="true" iconCls="icon-clear">清空</a></div>'
var  userList =  '<table id="sp" cellpadding=5 cellspacing=0 width=100% align="center" ><tr><td><ul class="ul_users checkbox"></ul></td></tr></table><p><input type="checkbox" id="chkall" ><label id="labchkall" for="chkall"><b>全选</b></label></p>' ;
//授权用户
function  accreditUsers() { 
     $( "a[rel='setuser']" ).click( function  () {
         if  ($( '#a_roleuser' ).linkbutton( 'options' ).disabled ==  true ) {
             return ;
         }
         var  i = $( 'table' ).data( 'tr_index' );
         if  (i == undefined) {
             top.$( '#notity' ).jnotifyAddMessage({ text:  '请选择角色.' , permanent:  false , type:  'warning'  });
             return  false ;
         }
         var  tds = $( '.grid2 tr:eq('  + i +  ') td' );
         var  rid = tds.eq(0).find( ':hidden' ).val();  //rid = $(this).attr('rid');
         top.$( '#w' ).hWindow({ html: formHtml, width: 500, height: 400, title:  '角色用户' , iconCls:  'icon-group_link' , submit:  function  () {
             var  users =  new  Array();
             var  count = top.$( '#user_groups' ).get(0).options.length;
             for  ( var  i = 0; i < count; i++) {
                 users.push(top.$( '#user_groups' ).get(0).options[i].value);
             }
             $.ajaxtext( 'handler/RoleAdminHandler.ashx' 'action=setusers&users='  + users +  '&roleid='  + rid,  function  (msg) {
                 if  (msg ==  "1" ) {
                     top.$( '#notity' ).jnotifyAddMessage({ text:  '设置成功。' , permanent:  false , type:  'message'  });
                 }
                 else
                     alert(msg);
                 top.$( '#w' ).window( 'close' );
             });
             return  false ;
         }
         });
         top.$( 'a.easyui-linkbutton' ).linkbutton({ disabled:  false  });
         top.$( '#role_name' ).text(tds.eq(2).text());
         top.$( '#txtroleremark' ).val(tds.eq(4).text());
         $.getJSON( 'handler/RoleAdminHandler.ashx?n='  + Math.random(),  '&action=usersinrole&roleid='  + rid,  function  (json) {
             $.each(json,  function  (i, n) {
                 top.$( '#user_groups' ).append( '<option value="'  + n.Id +  '">'  + n.UserName +  ' | '  + n.RealName +  '</option>' );
             });
         });
         top.$( '#group_add' ).click( function  () {
             top.$( '#d' ).hDialog({ html: userList, title:  '选取用户' , iconCls:  'icon-users' , width: 800, height: 600,
                 submit:  function  () {
                     var  selectedUids =  '' ;
                     top.$( '#sp :checked' ).each( function  () {  //匹配所有sp中被选中的元素(checkbox中被选中的)
                         if  (top.$( this ).is( ':checked' ))
                             selectedUids += top.$( this ).val() +  ',' ;
                     });
                     if  (selectedUids !=  '' )
                         selectedUids = selectedUids.substr(0, selectedUids.length - 1);
                     if  (selectedUids.length == 0) {
                         $.messager.alert( '请至少选择一个用户!' , msg,  'warning' );
                         return  false ;
                     else  {
                         var  users = top.$( '#sp' ).data( 'allusers' );
                         var  selarr = getSelectedUsers(users, selectedUids);
                         top.$( '#user_groups' ).empty();
                         top.$( '#sp' ).removeData( 'allusers' );
                         $.each(selarr,  function  (i, n) {
                             top.$( '#user_groups' ).append( '<option value="'  + n.Id +  '">'  + n.UserName +  ' | '  + n.RealName +  '</option>' );
                         });
                         top.$( '#d' ).dialog( "close" );
                     }
                 }
             });
             var  lis =  '' ;
             $.getJSON( 'handler/UserAdminHandler.ashx?n='  + Math.random(),  '' function  (json) {
                 $.each(json,  function  (i, n) {
                     lis +=  '<li><input type="checkbox" value="'  + n.Id +  '" /><label>'  + n.UserName +  ' | '  + n.RealName +  '</label></li>' ;
                 });
                 top.$( '.ul_users' ).empty().append(lis);
                 top.$( '#sp' ).data( 'allusers' , json);
             });
             top.$( '#labchkall' ).click( function  () {
                 var  flag = $( this ).prev().is( ':checked' );
                 var  pers = $( this ).parent().parent().prev();
                 if  (!flag) {
                     top.$( ":checkbox" '#sp' ).attr( "checked" true );
                 }
                 else  {
                     top.$( ":checkbox" '#sp' ).attr( "checked" false );
                 }
             });
         });
         top.$( '#group_delete' ).click( function  () {
             var  i = top.$( '#user_groups' ).get(0).selectedIndex;
             if  (i > -1) {
                 var  uid = top.$( '#user_groups option:selected' ).val();  //选中的值或 top.$("#user_groups").find("option:selected").val();
                 var  uname = top.$( '#user_groups option:selected' ).text();  //选中的文本 或top.$("#user_groups").find("option:selected").text();
                 top.$( '#user_groups' ).get(0).remove(i);
                 $.ajaxtext( 'handler/RoleAdminHandler.ashx' 'action=removeuserfromrole&uid='  + uid +  '&roleid='  + rid,  function  (msg) {
                     if  (msg ==  "1" ) {
                         top.$( '#notity' ).jnotifyAddMessage({ text:  '移除成功。' , permanent:  false , type:  'message'  });
                     }
                     else  {
                         top.$.messager.alert( '提示信息' , msg,  'warning' );
                     }
                 });
             }
             else  {
                 top.$.messager.alert( "操作提示" "请选择要移除的用户!" "info" );
             }
         });
         top.$( '#group_clear' ).click( function  () {
//            var count = $("#user_groups option").length
//            if (count <= 0) {
//                top.$.messager.alert("操作提示", "当前角色没有用户!", "info");
//                return;
//            }
             top.$.messager.confirm( '询问提示' '确认要清除所有用户吗?' function  (data) {
                 if  (data) {
                     top.$( '#user_groups' ).empty();
                 }
             });
             return  false ;
         });
     });
}

  特别说明一下,在选取用户界面,使用的是checkbox控件,得到选中的checkbox,是使用下面的实例代码:  

1
2
< input  id = "checkbox1"  type = "checkbox"  checked>
< input  id = "checkbox2"  type="checkbox>
1
2
3
4
5
$( "#checkbox1" ).is( ":checked" // true
$( "#checkbox2" ).is( ":checked" // false
//注意不是使用下面的方法
$( "#checkbox1" ).attr( "checked" // checked
$( "#checkbox2" ).attr( "checked" // undefined
  角色管理一般处理程序如下:

11144026-7a52dc76f7234faf8632ba11777d4b0


本文转自yonghu86 51CTO博客,原文链接:http://blog.51cto.com/yonghu/1321303,如需转载请自行联系原作者

相关文章
|
2月前
|
JavaScript
jQuery实现的滚动切换图表统计特效源码
jQuery实现的滚动切换图表统计特效源码是一段全屏滚动的企业当月运营报告数据统计图表代码,涵盖流行的线性、圆形、柱形图统计方式,适应于绝大多数企业,欢迎感兴趣的朋友前来下载参考。
25 2
|
2月前
jQuery+CSS3模拟过山车动态的文字动画特效源码
jQuery+CSS3模拟过山车动态的文字动画特效源码实现在全黑的背景下,画面中的文本呈现过山车的轨迹动画上下滚动转圈,且伴随文本颜色渐变效果,非常有意思,欢迎对此特效感兴趣的朋友前来下载参考。
25 1
|
2月前
|
JavaScript
jQuery制作的3D冰块立方时钟动态特效源码
jQuery制作的3D冰块立方时钟动态特效源码是一段基于jQuery实现的3D魔方立方时钟效果代码,该设计非常特别,且支持数字颜色的变化,提供8款颜色选择,非常有意思,欢迎对此段代码感兴趣的朋友前来下载使用。
40 8
|
2月前
|
JavaScript
jQuery制作的网站首页宽屏导航轮播图特效源码
jQuery制作的网站首页宽屏导航轮播图特效源码是一段基于jQuery制作的可用于商城首页 微商城 互联网公司或某些电子商城的首页特效,自带有二级菜单栏、轮播图滚动、登录注册按钮等等,非常全面,欢迎对此段代码感兴趣的朋友前来下载使用。
26 4
|
2月前
|
JavaScript
jQuery实现的手风琴四季场景变换特效源码
jQuery实现的手风琴四季场景变换特效源码是一段基于jQuery实现的手风琴四季场景变换效果代码,拥有春夏秋冬四季转场特效,鼠标可放大每个季节的图像,欢迎对此段代码感兴趣的朋友前来下载使用。
34 1
|
4月前
|
JSON 安全 JavaScript
Web安全-JQuery框架XSS漏洞浅析
Web安全-JQuery框架XSS漏洞浅析
586 2
|
3月前
|
移动开发 JSON 数据可视化
精选八款包括可视化CMS,jquery可视化表单,vue可视化拖拉,react可视化源码
精选八款包括可视化CMS,jquery可视化表单,vue可视化拖拉,react可视化源码
65 0
|
5月前
|
前端开发 关系型数据库 MySQL
Python基于Django框架图书管理系统,Bootstrap框架UI,后台EasyUI框架UI,有登录,实现增删改查的富文本效果
本文介绍了一个使用Python Django框架开发的图书管理系统,该系统采用Bootstrap框架进行前端UI设计,EasyUI框架用于后台UI界面,集成了富文本编辑器,并实现了登录及增删改查功能。
102 1
|
7月前
|
JavaScript 前端开发
杨校老师课堂之Web前端JS类库_JQuery案例[效果图与代码齐全]
杨校老师课堂之Web前端JS类库_JQuery案例[效果图与代码齐全]
40 0
|
7月前
切方块游戏 HTML5+jQuery【附源码】
切方块游戏 HTML5+jQuery【附源码】
46 0