django crm 左侧菜单栏

时间:2019-06-17
本文章向大家介绍django crm 左侧菜单栏,主要包括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