crm 一級菜單排序,二級菜單選中并且展開,非菜單權限的歸屬,權限粒度控制到按鈕級別...

排序

/rbac/templatetags/rbac.py

from django import template
from django.conf import settings
import re
from collections import  OrderedDict
register = template.Library()@register.inclusion_tag('rbac/menu.html')
def menu(request):ordered_dict=OrderedDict()menu_dict = request.session[settings.MENU_SESSION_KEY]# print(menu_dict,'111')ret=sorted(menu_dict,key=lambda x:menu_dict[x]['wight'],reverse=True)#俺排好序的 進行寫   然后按 有序字典 寫for i in ret:ordered_dict[i]=menu_dict[i]return {'menu_list': ordered_dict.values()}#返回有序字典

    for item in ordered_dict.values():for i in item['children']:if re.match(r'^{}$'.format(i['url']),request.path_info):i['class']='active'

?

?二級單選中展開

?

layout.html

<script>$('.multi-menu .title').click(function () {$(this).next().removeClass('hide');$(this).parent().siblings().find('.body').addClass('hide')})
</script>

可以寫入menu.js

?

?###########

?

?

init_permission.py

?存放ssion

?

?

?

?

可以整合到一個for字典中

?

?首頁導航

?

中間件中 寫入

#路徑導航列表

request.breadcumb_list=[{'title':'首頁','url':'/index/'}] 這個只能針對首頁


存入寫title

 

?

?應用

rbac/templatetags/rbac.py

@register.inclusion_tag('rbac/breadcrumb.html')
def breadcrumb(request):return {'breadcrumb_list':request.breadcrumb_list}

breadcrumb.html

<ol class="breadcrumb no-radius no-margin" style="border-bottom: 1px solid #ddd;">{% for i in breadcrumb_list %}{% if forloop.last %}<li class="active">{{ i.title }}</li>{% else %}<li><a href="{{ i.url }}">{{ i.title }}</a></li>{% endif %}{% endfor %}</ol>

?

權限控制到按鈕級別

?

第一種寫法

可以換成模版

在 web/templates/customer_list.html

{% extends 'layout.html' %}{% block content %}{% load rbac %}<div class="luffy-container"><div class="btn-group" style="margin: 5px 0">{#            {% if 'customer_add' in request.session.permission %}#}
            {% if request|has_permission:'customer_add' %}<a class="btn btn-default" href="/customer/add/"><i class="fa fa-plus-square" aria-hidden="true"></i> 添加客戶</a>{% endif %}</div><table class="table table-bordered table-hover"><thead><tr><th>ID</th><th>客戶姓名</th><th>年齡</th><th>郵箱</th><th>公司</th>{% if request|has_permission:'customer_edit' or request|has_permission:'customer_del' %}<th>選項</th>{% endif %}</tr></thead><tbody>{% for row in data_list %}<tr><td>{{ row.id }}</td><td>{{ row.name }}</td><td>{{ row.age }}</td><td>{{ row.email }}</td><td>{{ row.company }}</td>{% if request|has_permission:'customer_edit' or request|has_permission:'customer_del' %}<td>{% if request|has_permission:'customer_edit' %}<a style="color: #333333;" href="/customer/edit/{{ row.id }}/"><i class="fa fa-edit" aria-hidden="true"></i></a>{% endif %}{% if request|has_permission:'customer_del' %}<a style="color: #d9534f;" href="/customer/del/{{ row.id }}/"><iclass="fa fa-trash-o"></i></a>{% endif %}</td>{% endif %}</tr>{% endfor %}</tbody></table></div>
{% endblock %}

?

轉載于:https://www.cnblogs.com/zaizai1573/p/10575760.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/249381.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/249381.shtml
英文地址,請注明出處:http://en.pswp.cn/news/249381.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Maven工程的多模塊

一個大項目需要一個團隊來完成,然后一個大型項目就拆分成幾塊來同時開發,節省時間,提高效率. 大致分為以下幾個模塊(僅是自身經歷): 依賴管理工程模塊:一般現在開發都是以maven來管理jar包,方便.所以整個工程的依賴統一放在一個單獨工程中,一般叫做父工程xxx-parent. 注意事項…

《淺談架構之路:前后端分離模式》

前言&#xff1a;分離模式 對前后端分離研究了一段時間&#xff0c;恰逢公司有一個大項目決定嘗試使用前后端分離模式進行&#xff0c;便參與其中。該項目從2016年初立項至今&#xff0c;平平穩穩得度過&#xff0c;但也涌現出越來越多的問題&#xff0c;絕對不是說前后端分離模…

查詢語句

1.基本查詢語句 1.1 語法&#xff1a; SELECT 屬性列表 FROM 表名或視圖列表 WHERE 條件表達式1 GROUP BY 屬性名1 | HAVING 條件表達式2 ORDER BY 屬性名2 ASC DESC 2.單表查詢 1.應用&#xff1a;查詢表中所有的記錄 2.查詢指定字段&#xff1a;查詢表中所有name字段的記錄 …

Nodejs+Koa2+云服務ECS 開發微信公眾號(一)之環境配置

硬件準備工作 1. 本人采用阿里云的云服務器&#xff0c;購買了入門級云服務ECS&#xff08;293元每年&#xff09;&#xff1b; 2.針對服務器進行認證&#xff0c;設置個人服務器密碼&#xff1b; 3.購買數據盤&#xff0c;并將其掛載于云服務器之上&#xff08;建議掛載在/…

中文詞頻統計與詞云生成

本次作業來源于&#xff1a;https://edu.cnblogs.com/campus/gzcc/GZCC-16SE1/homework/2822 中文詞頻統計 1. 下載一長篇中文小說。 下載長篇小說《西游記》 本次作業小說保存在txt文檔&#xff1a;xyj.txt 2. 從文件讀取待分析文本。 xyj open(rF:/xyj.txt,r,encodingutf-8)…

java SWT Browser實現瀏覽器功能并運行JavaScript代碼

一、創建簡單的瀏覽器 import org.eclipse.swt.*; import org.eclipse.swt.browser.*; import org.eclipse.swt.layout.*; import org.eclipse.swt.widgets.*;public class Myswt3 {public static void main(String [] args) {Display display new Display();final Shell she…

[JZOJ5866]【NOIP2018模擬9.13】指引

Description Input Output Sample Input 6 3 2 0 3 1 1 3 4 2 0 4 5 5 Sample Output 2 Data Constraint Hint 貪心&#xff0c;把旅行者和出口的x坐標降序排序。 然后從前往后掃&#xff0c;如果是出口&#xff0c;就把y坐標插進set里&#xff0c;如果是旅行者&#xff0c;就查…

scrapy框架之遞歸解析和post請求

今日概要 遞歸爬取解析多頁頁面數據scrapy核心組件工作流程scrapy的post請求發送今日詳情 1.遞歸爬取解析多頁頁面數據 - 需求&#xff1a;將糗事百科所有頁碼的作者和段子內容數據進行爬取切持久化存儲 - 需求分析&#xff1a;每一個頁面對應一個url&#xff0c;則scrapy工程需…

SmartGit 過期解決方案之 非商業版本安裝使用

作為前端開發的小伙伴一定有這樣的困惑&#xff0c;自己在日常的團隊協作配合時&#xff0c;提交代碼和解決沖突是我們最頭疼的問題&#xff0c;但是又不喜歡使用Eclipse或者IDEA這種超級占內存的編輯器&#xff0c;使用Git命令又是那么捉襟見肘&#xff0c;所以有一個好用的輕…

HDU6438 Buy and Resell 解題報告(一個有趣的貪心問題的嚴格證明)

寫在前面 此題是一個很容易想到的貪心題目&#xff0c;但是正確性的證明是非常復雜的。然而&#xff0c;目前網上所有題解并未給出本題貪心算法的任何正確性證明&#xff0c;全部僅停留在描述出一個貪心算法。本著對算法與計算機科學的熱愛&#xff08;逃&#xff09;&#xff…

Webpack不生成index.html

沒有導出你的最后2個插件&#xff0c;并且沒有指定html文件名dist&#xff0c;因為HtmlWebpackPlugin應該生成相對于path&#xff0c;下面是固定配置&#xff1a; var path require(path)var webpack require(webpack)var HtmlWebpackPlugin require(html-webpack-plugin);m…

CSS3筆記之定位篇(一)relative

知識點1&#xff1a;relative和absolute relative: 相對自身&#xff0c;并會限制內部absolute元素層疊 absolute: 相對容器&#xff0c;并受到父類容器relative的影響&#xff0c;比如&#xff1a;overflow:hidden/scroll fixed: 不受relative限制&#xff0c;只受z-index的…

洛谷P3066 [USACO12DEC]逃跑的BarnRunning Away From…

題面鏈接 一句話題意&#xff1a;給出以1號點為根的一棵有根樹&#xff0c;問每個點的子樹中與它距離小于等于l的點有多少個。 我&#xff1a;似乎并不好做啊。。。看了題解后大霧。。。 sol&#xff1a;考慮樹上差分&#xff0c;對于一個點&#xff0c;在他那個位置&#xff0…

vue使用webPack打包發布后頁面顯示空白

今天筆者將打包后&#xff0c;進行訪問&#xff0c;訪問到index.html&#xff0c;但是出現的是空白頁。 打包命令&#xff1a;npm run build&#xff0c;打包后的文件如下&#xff1a; 這是因為index.html中引入的css ,js 的路徑不對:如下圖 這個是因為webpack打包的時候引入…

第一次實驗報告

c程序實驗報告 姓名&#xff1a;黃志乾 實驗地點&#xff1a;教學樓514教室 實驗時間&#xff1a;3月19日實驗項目: 1、字符與ASCII碼 2、運算符與表達式的應用 3、順序結構應用程序 4、數學函數的算法描述 5、雞兔同籠的算法描述 6、確定坐標的算法描述…

Mac下Idea安裝Git報錯Xcrun問題的解決

使用過IDEA的小伙伴都知道&#xff0c;它和我們之前用過的Eclipse一樣強大&#xff0c;或者比他更強大。當它配合的Mac使用時&#xff0c;就會變得更得心應手&#xff0c;少去很多環境配置的環節。其中最典型的就是Git 由于Mac自帶就安裝了git, 大家可以通過終端輸入命令“git…

關于Django路由層簡單筆記

Django—路由層 URL配置(URLconf)就像Django 所支撐網站的目錄。它的本質是URL與要為該URL調用的視圖函數之間的映射表&#xff1b;你就是以這種方式告訴Django&#xff0c;對于客戶端發來的某個URL調用哪一段邏輯代碼對應執行。 1&#xff0c;簡單的路由配置 from django.urls…

hdu 5183

hdu 5183(Hash處理區間問題) 題目鏈接:http://acm.hdu.edu.cn/showproblem.php?pid5183 題意:給出一個n個元素的數組,現在要求判斷 a1-a2a3-a4...../-an 中是否存在某個某個區間使得 ai-ai1ai2...(-1)j-iaj k?? 這個題要利用Hash就可以實現幾乎在 O(n) 的時間內實現查找判斷…

vue-cli,webpack安裝

第一步應該下載node.js這是安裝vue-cli的基礎工具。官網下載快捷安全可&#xff1a;https://nodejs.org/en/ 第二步打開命令面板找到你要安裝的位置 第三步就是安裝全局vue-cli 命令操作 npm intatll -g vue-cli 安裝完畢之后 可以檢查安裝版本即 vue -V 如下圖 這還不算完&…

CSS3筆記之定位篇(二)z-index

知識點1&#xff1a;z-index基礎 z-index&#xff1a;auto; 默認值 z-index: <integer> 整數 z-index: inherit 繼承 不考慮css3 還有定位元素的z-index才有作用 知識點2&#xff1a;z-index與定位元素 無嵌套&#xff1a;后來居上&#xff0c;哪個大哪個上 //在沒有…