本系列前三章:

http://www.cnblogs.com/CQ-LQJ/p/5604331.htmlPermission权限基本操作指令

http://www.cnblogs.com/CQ-LQJ/p/5609690.htmlUser权限基本操作指令

http://www.cnblogs.com/CQ-LQJ/p/5620490.html设计自有权限管理系统设计思路

正文:

权限管理界面分三部分:一个点击进入该页面的按钮、以及该页面的权限列表、添加按钮,删除按钮;

权限管理界面页面是最基础的设计,并且和用户权限分配界面有着重要的关系.

首先需要在template,简称模板中加入一个点击按钮,功能是进入权限管理页面,代码如下:

 <p class="text-center"><button id="qxgl" class="btn">权限管理</button></p>

该按钮的功能大致为:

利用ajax局部刷新出权限管理界面网页,且使用ajax中getJSON函数从后端view中返回所有权限信息(codename为中文的权限)以及相关添加删除按钮.

HTML页面编写javascript之前,先将必要的HTML标签写好,我们这里需要一个表格(table)和表单(form),如下:

<form>
{% csrf_token %}
<div id="interface"></div>
<table class="table" id="t1">
<caption></caption>
<thead></thead>
<tbody></tbody>
<tfoot></tfoot>
</table>
</form>

接下来我们看按钮函数如何编写:

      $('#qxgl').click(function(){//权限管理
$("#interface").html("<h3>权限管理操作界面</h3>"+
"<p class='text-error'><strong>你可以选择对应权限, <button class='btn btn-small btn-danger' type='button' id='perm_del'>点击此处</button>进行删除,也可以点击左侧权限管理按钮刷新权限页面!</strong></p>")
$("#t1 thead").html("<tr style='background-color:#C0C0C0;'><th>单选框</th><th>权限类型</th><th>权限名称</th><th>权限描述</th></tr>");
$.getJSON("{% url 'permmanage' %}",
function(ret){
$('#t1 tbody').empty();$('#t1 tfoot').empty();
for (var i = 0; i <= ret.length - 1; i++) {
$('#t1 tbody').append("<tr><td><input type='radio' name='permission' value='"+ret[i].codename+"'></td>"+
"<td>"+ret[i].content_type_id+"</td><td>"+ret[i].codename+"</td>"+
"<td>"+ret[i].name+"</td></tr>");
}
$('#t1 tfoot').append("<tr><td>"+
"<button class='btn btn-small btn-success' type='button' id='perm_add'>新增权限</button>"+
"</td>"+
"<td><input type='text' class='input-mini' placeholder='.input-mini' id='id'></td>"+
"<td><input type='text' class='input-medium' placeholder='.input-medium' id='codename'></td>"+
"<td><input type='text' class='input-xxlarge' placeholder='.input-xxlarge' id='name'></td>"+
"</tr>");
});
})

上面代码中$.getJSON的功能是从后台返回所有中文权限的json参数到前台,另外到这里我们需要知道两件事情:
第一:django的permisson有三个字段,分别对应content_type_id 权限类型,codename 权限名称,name 权限描述,permission的用法跟普通的模型使用一样

第二:查询中文权限需要用到正则表达式,需要用到模型api中的iregex,查询全部中文权限代码:

Permission.objects.filter(codename__iregex=u'[\u4e00-\u9fa5]').values()

好了,到这里我们跳到django后端配置url和view便可实现该按钮功能:
配置url:

home_patterns = [
url(r'permmanage/$', 'home.views.permmanage', name='permmanage'),
] urlpatterns = [
url(r'^$', 'login.views.login_view', name='login_view'),
# url(r'^blog/', include('blog.urls')),
url(r'^home/', include(home_patterns)),
url(r'^admin/', include(admin.site.urls)),
]

配置view:

def permmanage(request):    #正则匹配中文u'[\u4e00-\u9fa5]'
d = Permission.objects.filter(codename__iregex=u'[\u4e00-\u9fa5]').values()
dlist = []
for i in d:
dlist.append(i)
return JsonResponse(dlist, safe=False)

下面编写对应的权限添加和删除操作,这里我便不详细说明了,具体可查看本系列文章中Permission权限基本操作指令

具体代码如下

view.py:

#权限添加
def permaddtion(request):
content_type_id = request.POST['id']
codename = request.POST['codename']
name = request.POST['name']
if Permission.objects.filter(codename = codename).exists():
relist = {'re':'该权限已存在,添加失败!'}
return JsonResponse(relist)
else:
Permission.objects.create(content_type_id=int(content_type_id),codename=codename,name=name)
relist = {'re':'该权限添加成功!'}
return JsonResponse(relist)
#权限删除
def permdeletion(request):
codename = request.POST['codename']
Permission.objects.get(codename=codename).delete()
relist = {'re':"该权限删除成功!"}
return JsonResponse(relist)

url.py:

#首页url配置
home_patterns = [
url(r'permaddtion/$', 'home.views.permaddtion', name='permaddtion'),
url(r'permdeletion/$', 'home.views.permdeletion', name='permdeletion'),
]

template:

      $('#t1').on("click","#perm_add",function(){//添加权限
var tj1 = $("#id").val(); var tj2 = $("#codename").val(); var tj3 = $("#name").val();
var pattern = /^[\u4E00-\u9FA5]{1,10}$/;
if( tj1== ""){alert("权限类型必填!");}
else{
if(isNaN(tj1)){alert("权限类型必须为数字!");}//数字判断
else{
if(tj2 == ""){alert("权限名称必填!");}
else{
if(!pattern.test(tj2)){alert("权限名称必须为中文!");}//中文判断
else{
if( tj3 == ""){alert("权限内容必填!");}
else{//条件判断完毕,进行后台操作
$.post("{% url 'permaddtion' %}",//是,则进行下一步操作
{
csrfmiddlewaretoken:"{{ csrf_token }}",
id:tj1,
codename:tj2,
name:tj3,
},
function(ret) {
alert(ret['re']);
});
}}}}}
})
$('#interface').on("click","#perm_del",function(){//删除权限
var re = $("input[name='permission']:checked").val();//获取权限名称
var pattern = /^[\u4E00-\u9FA5]{1,10}$/;
if (!pattern.test(re)){alert("请选择一个权限名称,再进行删除权限操作!");}//判断是否选择单选框
else{
$.post("{% url 'permdeletion' %}",//是,则进行下一步操作
{
csrfmiddlewaretoken:"{{ csrf_token }}",
codename:re,
},
function(ret) {
alert(ret['re']);
});
}
})

[Django]用户权限学习系列之权限管理界面实现的更多相关文章

  1. Django用户登陆以及跳转后台管理页面3

    Django用户登陆以及跳转后台管理页面1http://www.cnblogs.com/ujq3/p/7891774.html Django用户登陆以及跳转后台管理页面2http://www.cnbl ...

  2. Django用户登陆以及跳转后台管理页面2

    请先写好以下,再来替换文件 Django用户登陆以及跳转后台管理页面1http://www.cnblogs.com/ujq3/p/7891774.html from django.shortcuts ...

  3. Spring5.0源码学习系列之事务管理概述

    Spring5.0源码学习系列之事务管理概述(十一),在学习事务管理的源码之前,需要对事务的基本理论比较熟悉,所以本章节会对事务管理的基本理论进行描述 1.什么是事务? 事务就是一组原子性的SQL操作 ...

  4. .net reactor 学习系列(二)---.net reactor界面各功能说明

    原文:.net reactor 学习系列(二)---.net reactor界面各功能说明         安装了.net reactor之后,可以在安装目录下找到帮助文档REACTOR_HELP.c ...

  5. Android学习系列(23)--App主界面实现

    在上篇文章<Android学习系列(22)--App主界面比较>中我们浅略的分析了几个主界面布局,选了一个最大众化的经典布局.今天我们就这个经典布局,用代码具体的实现它. 1.预览图先看下 ...

  6. [Django]用户权限学习系列之设计自有权限管理系统设计思路

    若在阅读本片文章遇到权限操作问题,请查看本系列的前两章! http://www.cnblogs.com/CQ-LQJ/p/5609690.html和http://www.cnblogs.com/CQ- ...

  7. [Django]用户权限学习系列之User权限基本操作指令

    针对Django 后台自带的用户管理系统,虽说感觉还可以,但是为了方便用户一些操作,特别设计自定义的用户权限管理系统. 在制作权限页面前,首先需要了解权限和用户配置权限的指令,上章讲到权限的添加,删除 ...

  8. [Django]用户权限学习系列之Permission权限基本操作指令

    若需建立py文件进行测试,则在文件开始加入以下代码即可 #coding:utf-8 import os os.environ.setdefault("DJANGO_SETTINGS_MODU ...

  9. 「Django」rest_framework学习系列-权限认证

    权限认证:1.项目下utils文件写permissions.py文件 from rest_framework.permissions import BasePermission class SVIPP ...

随机推荐

  1. Jquery的点击事件,三句代码完成全选事件

    先来看一下Js和Jquery的点击事件 举两个简单的例子 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN&q ...

  2. DB1:数据库的创建和文件的修改

    在SQL Server中,使用Create Database创建数据库,使用Alter Database命令,能够修改数据库的数据文件和日志文件. 一,创建数据库 1,在创建数据库时,最佳实践是: 创 ...

  3. JavaScript function函数种类

    本篇主要介绍普通函数.匿名函数.闭包函数 目录 1. 普通函数:介绍普通函数的特性:同名覆盖.arguments对象.默认返回值等. 2. 匿名函数:介绍匿名函数的特性:变量匿名函数.无名称匿名函数. ...

  4. 【踩坑速记】开源日历控件,顺便全面解析开源库打包发布到Bintray/Jcenter全过程(新),让开源更简单~

    一.写在前面 自使用android studio开始,就被它独特的依赖方式:compile 'com.android.support:appcompat-v7:25.0.1'所深深吸引,自从有了它,麻 ...

  5. iOS架构一个中型普通App的一些经验总结

    这一版比较完善的的App终于提交审核了.有时间写写自己的一些经验的总结了.自己主导的从0到比较成型的app到目前来说也只有两个,但是其中的很多东西都是大同小异.基本上是想到了什么就写什么,感觉写的不到 ...

  6. VS项目中使用Nuget还原包后编译生产还一直报错?

    Nuget官网下载Nuget项目包的命令地址:https://www.nuget.org/packages 今天就遇到一个比较奇葩的问题,折腾了很久终于搞定了: 问题是这样的:我的解决方案原本是好好的 ...

  7. bzoj4724--数论

    题目大意: B进制数,每个数字i(i=0,1,...,B-1)有a[i]个.你要用这些数字组成一个最大的B进制数X(不能有前导零,不需要 用完所有数字),使得X是B-1的倍数.q次询问,每次询问X在B ...

  8. JavaScript 正则表达式语法

    定义 JavaScript定义正则表达式有两种方法. 1.RegExp构造函数 var pattern = new RegExp("[bc]at","i"); ...

  9. 解决使用IE8打开ADFS 3.0登录页面

    系统上线前一天,发现客户竟然有XP系统和2003系统,这些系统都不能访问外网.测试时,客户端是IE8,打开我们系统ADFS的登录页面,一直在Loading,无法打开,也不报错.后来通过fiddler跟 ...

  10. git提交项目到已存在的远程分支

    今天想提交项目到github的远程分支上,那个远程分支是之前就创建好的,而我的本地关联分支还没创建.   之前从未用github提交到远程分支过,弄了半个钟,看了几篇博文,终于折腾出来.现在把步骤整理 ...