01-自定制页面

注:最近找到了更好的解决办法:重写钩子函数版  https://www.cnblogs.com/pgxpython/p/10593507.html

需求背景:根据要实现的功能需求,xadmin的后台页面不满足现有要求,需要进行自定义页面来替换后台固有页面,所以要在源码上入手

修改前的页面:

修改后的效果:

解决方法:

xadmin的处理流程和django类似,都是通过拦截URL,然后封装数据,再在页面解析。

思路:

.在views/base.py中添加控制(是否需要跳转,跳转的url)

.在templates/xadmin/base_site.html 中根据上一步传过来的值控制显示内容(用iframe) 或者 在 base_site.html 里添加自定义的HTML内容 (我就是添加的html代码)

.自己编写处理该url的页面和view.py,然后iframe中就会显示该页面

实现代码:

# xadmin/views/base.py

class CommAdminView(BaseAdminView):
@filter_hook
def get_context(self):
for menu in nav_menu:
check_selected(menu, self.request.path) # 添加自定义url,视图函数获取数据
add_url_flag = False
auto_title = ''
pid = ''
subtitle = ''
print(self.request.get_full_path())
if '/xadmin/cashflows/cash_title_content/' in self.request.get_full_path():
from apps.cashflows.models import cash_title_link, cash_title_content
add_url_flag = True
auto_title = cash_title_link.objects.all()
# print('title', title)
pid = self.request.GET.get('pid')
# print('pid', pid, type(pid))
if pid:
subtitle = cash_title_content.objects.filter(content_cash_id=pid)
pid = int(pid)
else:
subtitle = None
else:
pass print('auto_title', auto_title)
print('pid', pid)
print('subtitle', subtitle)
context.update({
'menu_template': self.menu_template,
'nav_menu': nav_menu,
'site_title': self.site_title,
'site_footer': self.site_footer,
'breadcrumbs': self.get_breadcrumb(), # 自定义获取的数据,返回给base_site.html页面
'add_url_flag': add_url_flag,
'auto_title': auto_title,
'subtitle': subtitle,
'pid': pid,
}) return context
# xadmin/templates/xadmin/base_site.html

    {% if add_url_flag %}
<div class="col-sm-3 col-sm-offset-1 panel panel-primary" style="padding: 0;">
<div class="panel-heading">表单项目名称表</div>
<div style="width:389px; height:347px; overflow:scroll; text-align: center">
<table class="table table-hover">
<tr>
<th style="text-align: center">序号</th>
<th style="text-align: center">表单名称</th>
</tr>
{% for i in auto_title %}
<tr class="{% if pid == forloop.counter %}active{% endif %}">
<td >{{ forloop.counter }}</td>
<td ><a href="?pid={{ forloop.counter }}">{{ i }}</a></td>
</tr>
{% endfor %}
</table>
</div>
</div>
<div class="col-sm-3 col-sm-offset-1 panel panel-success" style="padding: 0;">
<div class="panel-heading">表单名称下的标题</div>
<div style="width:389px; height:347px; overflow:scroll; text-align: center">
<table class="table" style=" text-align: center">
<tr>
<th style="text-align: center">序号</th>
<th style="text-align: center">标题</th>
</tr> {% for a in subtitle %}
<tr>
<td>{{ forloop.counter }}</td>
<td>{{ a }}</td>
</tr>
{% endfor %}
</table>
</div>
</div>
{% else %}
{% block content %}
{#此处为 原有的后台显示内容及页面展示样式#}
{{ content }}
{% endblock %}
{% endif %}

base_site.html部分源码介绍:

{% block breadcrumbs %}
<ul class="breadcrumb">
{% if breadcrumbs %}
{% for bc in breadcrumbs %}
<li>
{% if forloop.last or not bc.url %}{{ bc.title }}
{% else %}<a href="{{ bc.url }}">{{ bc.title }}</a>{% endif %}
</li>
{% endfor %}
{% else %}
<li><a href="{% url 'xadmin:index' %}">{% trans 'Home' %}</a></li>
{% if title %}{{ title }}{% endif %}
{% endif %}
</ul>
{% endblock %}

以上代码实现的效果为:

{% block content-nav %}
<div class="navbar content-navbar navbar-default navbar-xs" data-toggle="breakpoint"
data-class-xs="navbar content-navbar navbar-inverse navbar-xs"
data-class-sm="navbar content-navbar navbar-default navbar-xs">
<div class="navbar-header">
{% view_block 'nav_toggles' %}
{% block nav_toggles %}
{% include "xadmin/includes/toggle_back.html" %}
{% endblock %} <a class="navbar-brand" data-toggle="collapse" data-target="#top-nav .navbar-collapse">
{% block nav_title %}{% endblock %}
</a>
</div>
<div class="navbar-collapse collapse">
<ul class="nav navbar-nav">
{% view_block 'nav_menu' %}
</ul>
{% view_block 'nav_form' %}
{% block nav_form %}{% endblock %}
<div class="navbar-btn pull-right hide-xs">
{% view_block 'nav_btns' %}
{% block nav_btns %}{% endblock %}
</div>
</div>
</div>
{% endblock %}

以上代码实现的效果为:

参考文章:https://www.cnblogs.com/lanqie/p/8675533.html

xadmin后台页面的自定制的更多相关文章

  1. xadmin后台页面的自定制(2)重写钩子函数版

    由于项目有通过自定义页面来实现功能的需求,百度也查了很多资料,也没找到合适的方法,所以决定分析源码,通过对源码的分析,找到了此方法. 01-需求 首先,如果要在xadmin中展示一个数据管理页面,首先 ...

  2. xadmin后台页面定制和添加服务器监控组件

    xadmin定制 项目需要添加服务器监控页面,碍于xadmin不是很好自定义页面,之前写过插件,太麻烦了,还是直接改源码 原理其实很简单,因为xadmin的处理流程和django类似,都是通过拦截UR ...

  3. django xadmin后台页面实现二级联动

    思路 先找到控件id ,这样就可以监听change事件 然后把自己写的js加入xadmin中 添加url和view,接受ajax请求和发送数据 第一步:找到联动上下级的ID 在浏览器中通过F12查看 ...

  4. python测试开发django-54.xadmin添加自定义页面

    前言 xadmin后台如何添加一个自己写的页面呢?如果仅仅是在GlobalSettings添加url地址的话,会丢失左侧的导航菜单和顶部的页面,和整体的样式不协调. 新增页面后希望能保留原来的样式,只 ...

  5. 第三百九十四节,Django+Xadmin打造上线标准的在线教育平台—Xadmin后台进阶开发配置2,以及目录结构说明

    第三百九十四节,Django+Xadmin打造上线标准的在线教育平台—Xadmin后台进阶开发配置2,以及目录结构说明 设置后台列表页面可以直接修改字段内容 在当前APP里的adminx.py文件里的 ...

  6. 自定义xadmin后台首页

    登陆xadmin后台,首页默认是空白,可以自己添加小组件,xadmin一切都是那么美好,但是添加小组件遇到了个大坑,快整了2个礼拜,最终实现想要的界面.初始的页面如图: 本机后台显示这个页面正常,do ...

  7. python测试开发django-39.xadmin详情页面布局form_layout

    前言 xadmin的详情页面默认是一行展示一个字段,可以使用form_layout对详情页面的布局重新设计. 可以设置必填和非必填字段,也可以设置不显示,不可以编辑的字段. models模块 先在mo ...

  8. 轮播图和xadmin后台管理

    一.数据库设计 轮播图 1.安装依赖 pip install Pillow 2.模型类:home/models.py class Banner(models.Model): ""& ...

  9. MVC 从后台页面 取前台页面传递过来的值的几种取法

      MVC 从后台页面 取前台页面传递过来的值的几种取法   <1>前台页面 Index视图 注意:用户名表单的name值为txtName 密码表单的name值为txtPassword & ...

随机推荐

  1. [20181225]12CR2 SQL Plan Directives.txt

    [20181225]12CR2 SQL Plan Directives.txt --//12C引入SQL PLAN Directives.12cR1版本会造成大量的动态取样,影响性能.许多人把OPTI ...

  2. SQL Server基础之登陆触发器

    虽然同表级(DML)触发器和库级(DDL)触发器共顶着一个帽子,但登陆触发器与二者有本质区别.无论表级还是库级,都是用来进行数据管理的,而登陆触发器是纯粹的安全工具. 登陆触发器只响应LOGON事件, ...

  3. 反射生成 INSERT 多个对象的 SQL 语句(批量插入)

    + View code private static void insertObject(List<?> objectList) throws IllegalAccessException ...

  4. 【audio】耳机插拔 线控按键识别流程【转】

    耳机插拔/线控按键识别流程 耳机插拔/线控按键识别流程 1.文档概述 本文以msm8909平台,android N为例,介绍了通用情况下,耳机插拔的流程步骤,以及对耳机类型的识别逻辑.以方便在项目工作 ...

  5. Windows Server 2016-管理站点复制(一)

    可以使用Active Directory站点和服务管理单元来管理实现站点间复制拓扑的特定于站点的对象.这些对象存储在Active Directory域服务 (AD DS) 的站点容器中.同一个站点内的 ...

  6. PHP实现类似题库抽题效果

    PHP实现类似题库抽题效果 大家好,我顾某人又回来了,最近学了一点PHP,然后就想写个简单小例子试试,于是就写了一个类似于从题库抽题的东西,大概就是先输入需要抽题的数量,然后从数据库中随机抽取题目. ...

  7. Git&GitHub语法大全

    目录 1. GitHub与Git万用语法 1)创建库 2)添加和提交到仓库 3)版本回退 4)缓存区和暂存区 5)撤销和删除文件 6)远程仓库 7)创建和合并分支 2. 更多Git语法 1. GitH ...

  8. 在模态框(Modal)中使用UEditor全屏显示的一个坑

    根据这个问题很简单就能查到一些文章明确说明了解决问题的方法,就是如下一段代码: var isModal = false; //判断该dom是否为modal var classes = $(contai ...

  9. 小程序背景图片bug

    在pc端调试的时候已经可以看到出现背景图片了,但是在真机调试的时候却发现没有背景图片,那么原因是什么呢?真机调试和vconsole也看不出什么鸟,其实这是小程序的一个bug.另一种说法是:backgr ...

  10. Linux 内核学习经验总结

    Linux 内核学习经验总结 学习内核,每个人都有自己的学习方法,仁者见仁智者见智.以下是我在学习过程中总结出来的东西,对自身来说,我认为比较有效率,拿出来跟大家交流一下. 内核学习,一偏之见:疏漏难 ...