django crm 左侧菜单栏

 

  1. 在app中创建一个service文件夹,将 权限认证中间件, 和 将权限注入session的函数写入该文件夹
  2. 控制左侧菜单栏显示项:
    1. 给permission表加一项 , is_menu, 值为True表示要在左侧菜单栏中显示,值为False表示不需要在左侧菜单栏中显示
    2. 将权限向session中注入的时候,注入两个列表
      1. permission_list 列表 表示所有权限,用于在中间件中判断该用户是否有权限执行当前操作
      2. permission_menu_list 列表,可以在前端页面循环此列表生成 左侧菜单兰
  3. 生成左侧菜单栏有两种方式
    1. 直接在前端页面 for 循环 permission_menu_list 直接生成
    2. 自定义一个标签,用 @register.inclusion_tag 来完成标签生成工作  

  权限注入:

from rbac import models

def initial_session(request,user_obj):
    permission_obj = models.Permission.objects.filter(role__user=user_obj).distinct()
    # print(permission_obj)

    permission_list = []
    permission_menu_list = []
    for item in permission_obj:

        permission_list.append(item.url)
        if item.is_menu:
            permission_menu_list.append({'title':item.title,'url':item.url,'icon':item.icon})
    # permission_list = [i.url for i in permission_obj]
    request.session['permission_list'] = permission_list
    request.session['permission_menu_list'] = permission_menu_list

方式一:直接循环标签生成html标签

  {% for foo in request.session.permission_menu_list %}
                <div>
                    <i class="fa {{ foo.icon }}"></i>
                    <a href="{{ foo.url }}">{{ foo.title }}</a>
                </div>
            {% endfor %}

方式二:通过自定义的标签, 生成html标签返回给页面

  在主页面中引入

            {% load rbac %}
            {% menu request %}        

  templatetags-->rbca.py

from django import template
register = template.Library()
import re


@register.inclusion_tag('rbac/menu.html')
def menu(request):
    menu_list = request.session.get('permission_menu_list')
    for item in menu_list:
        url = item['url']
        if re.match('{}'.format(url),request.path_info):
            item['active'] = 'active'
            break
    return {'menu_list':menu_list}

  templates-->rbca-->menu.html

<div class="static-menu">

    {% for item in menu_list %}
        {% if item.active %} #判断当前标签是否是选中标签,添加active属性
            <a href="{{ item.url }}" class="{{ item.class }} active">
            <span class="icon-wrap"><i class="fa {{ item.icon }}"></i></span> {{ item.title }}</a>
        {% else %}
            <a href="{{ item.url }}" class="{{ item.class }} ">
            <span class="icon-wrap"><i class="fa {{ item.icon }}"></i></span> {{ item.title }}</a>
        {% endif %}
    {% endfor %}

</div>

 

 

  

转载于:https://www.cnblogs.com/zhangjian0092/p/11042251.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值