zoukankan      html  css  js  c++  java
  • 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>

      

  • 相关阅读:
    2015.07-2015.08
    the last lecture
    强化的单例属性_Effective Java
    Socket通信客户端设计(Java)
    静态工场方法代替构造器
    如何控制Java中的线程,总结了3种方法...
    如何快速转型,比如C#...to...Java
    C#中var和dynamic
    How to use the Visual Studio
    mark blog
  • 原文地址:https://www.cnblogs.com/zhangjian0092/p/11042251.html
Copyright © 2011-2022 走看看