将DJANGO管理界面的filter_horizontal移到前面来复用
参考URL:
http://www.hoboes.com/Mimsy/hacks/replicating-djangos-admin/reusing-djangos-filter_horizontal/
http://www.hoboes.com/Mimsy/hacks/replicating-djangos-admin/
我要想的东东,没有上面讲的那么复杂,就是想在用户操作M2M时,可以从容的选择不同的选项,而不用担心哪些东东被漏了。
按上面的文档,我的实现如下:
一,新建一个模板文档,将相关的DJANGO管理里的CSS,JS移出来备用。
popupplus.html(注意初始化的参数,0为横向,1为纵向)
{% load staticfiles %} <link rel="stylesheet" href={% static "admin/css/widgets.css"%} /> <script src={% static "/admin/jsi18n/"%}></script> <script src={% static "admin/js/core.js"%}></script> <script src={% static "admin/js/SelectBox.js"%}></script> <script src={% static "admin/js/SelectFilter2.js"%}></script> {% if multiple %} <script type="text/javascript"> addEvent(window, "load", function(e) { SelectFilter.init("id_{{ field }}", "{{ field }}", 0, "/static/admin/"); }); </script> {% endif %}
二,重写forms.py里的代码,让其继承forms.SelectMultiple来改写:
class MultipleSelectWithPop(forms.SelectMultiple): def render(self, name, *args, **kwargs): html = super(MultipleSelectWithPop, self).render(name, *args, **kwargs) popupplus = render_to_string("rightmanage/popupplus.html", {'field': name, 'multiple': True}) return html+popupplus
三,让相关字段继承这个类,来实现横向选择。
class RightManageFATForm(forms.ModelForm): def __init__(self, *args, **kwargs): super(RightManageFATForm, self).__init__(*args, **kwargs) fat_users = forms.ModelMultipleChoiceField( User.objects, widget=MultipleSelectWithPop, ) name = forms.CharField( required=False, error_messages={'required': "不能为空"}, label=u"项目名称", widget=forms.TextInput( attrs={ 'class': 'uk-width-1-4', 'disabled': 'true', } ), ) class Meta: model = Site fields = ['name', 'fat_users', ] exclude = ['app_name', 'description', 'app_name', 'manage_user', 'uat_users', 'prd_users', 'valid_users', ]
四,然后,,好像就抽定啦。。。:)好像字体没调好,暂时不管。。。
将DJANGO管理界面的filter_horizontal移到前面来复用的更多相关文章
- iOS开发UI篇—在UITableview的应用中使用动态单元格来完成app应用程序管理界面的搭建
iOS开发UI篇—在UITableview的应用中使用动态单元格来完成app应用程序管理界面的搭建 一.实现效果 说明:该示例在storyboard中使用动态单元格来完成. 二.实现 1.项目文件结构 ...
- C#_会员管理系统:开发二(会员资料管理界面的‘增删改查’)
会员资料管理界面: 新建一个窗体,窗体界面和控件如下: 窗体中的控件dgvManager更改FullRowSelect属性(点击选中效果)为:FullRowSelect 会员资料管理界面窗体的详细代码 ...
- 8 django 里面的API
1.什么是API? 2.在djang里面写API 3.API实战效果 1.移动端的网页 4.restframework :老师方法 (0)安装 Django REST framework 是一个强大且 ...
- Django里面的RequestContext
c = RequestContext(request, { 'foo': 'bar', }) get_template('about.html').render(c) 当我们定义一个RequestCo ...
- 通过Eclipse3.1以上启动Tomcat访问不到tomcat管理界面的问题(转载)
通过Eclipse插件启动Tomcat的问题 默认分类 2009-10-23 15:54 阅读118 评论0 字号: 大 中 小 目前在通过Eclipse中插件启动Tomcat时遇 ...
- Solr 05 - Solr Web管理界面的基本使用
目录 1 Dashboard - 仪表盘 2 Logging - 日志信息 3 CoreAdmin - Solr核心 4 Java Properties - Java参数 5 Thread Dump ...
- kafka-manager:kafak的管理界面的安装和使用
下载打包 release下载:https://github.com/yahoo/kafka-manager/releases 源码位置:https://github.com/yahoo/kafka-m ...
- 【Rocket MQ】RocketMQ 在windows7 64位安装使用 +RocketMQ管理界面的安装
参考地址:https://blog.csdn.net/yucaifu1989/article/details/80960018 参考地址:https://blog.csdn.net/u01204090 ...
- Win7系统打开服务管理界面的几种方法汇总
转自:https://www.jb51.net/os/windows/318465.html Win7服务管理包含了计算机操作系统和应用程序提供的所有服务,但是这么多服务并非总是用户所需的.比如打印机 ...
随机推荐
- 【笔记】Windows Phone 8开发笔记之API
Windows Phone 8 API一览 Windows Phone 7平台不支持Native语言的开发,这困扰了许多游戏和底层应用的开发者.Windows Phone 8 SDK的推出,改善了这个 ...
- java基础-注解Annotation原理和用法
在很多java代码中都可以看到诸如@Override.@Deprecated.@SuppressWarnings这样的字符,这些就是注解Annotation.注解最早在jdk5中被引入,现在已经成为j ...
- Qt for Android 程序禁止屏幕旋转
有时候我们希望让一个程序的界面始终保持在一个方向,不随手机(平板)方向旋转而变化:在AndroidManifest.xml的每一个需要禁止转向的Activity配置中加入 android:screen ...
- c++11: bind用法
原型: template< class R, class F, class... Args > bind( F&& f, Args&&... args ); ...
- PHP 判断客户端请求是 Android 还是 IOS
<?php if(strpos($_SERVER['HTTP_USER_AGENT'], 'iPhone')||strpos($_SERVER['HTTP_USER_AGENT'], 'iPad ...
- php文本操作方法集合比较第2页
fgets和fputs.fread和fwrite.fscanf和fprintf 格式化读写函数fscanf和fprintf fscanf函数,fprintf函数与前面使用的scanf和printf 函 ...
- trade 主要前端组件
jQuery Custombox http://www.jqueryfuns.com/resource/view/27
- java dom4j解析xml用到的几个方法
1. 读取并解析XML文档: SAXReader reader = new SAXReader(); Document document = reader.read(new File(fileName ...
- Linux nmon 监控工具使用
Linux 系统下监控指标及指标查看 一.工具介绍 Linux 系统下资源监控使用nmon 工具.它可以帮助在一个屏幕上显示所有重要的性能优化信息,并动态地对其进行更新且并不会消耗大量的CPU ...
- 【mongodb】 需求
增删改查 增加: (表名,增加内容) 删除: (表名,数据id) 改: (表名 根据id获取数据 修改 增加 查 (表名,字段 ) 关联查询? 请主站提供一下 在使用的接口