zoukankan      html  css  js  c++  java
  • django中的admin组件之自定义组件的filter,pop

    今天我们来实现一下admin中,右边的filter和pop的功能。

    先来实现filter的功能。

    我们先来想一下步骤:

    首先我们要在页面中显示这样一个标签。当我们  list_filter = [ "publish", "authors"]

    我们要在页面上显示的是publish和author的所有数据。这应该怎么做?

    我们怎么能拿到这些数据?这一部分是在页面中显示的,所以应该放在showlist的类中。

    {‘publish’:[<Publish: 沙河出版社>, <Publish: 西二旗出版社>, <Publish: 山西出版社>,]}   只要构造成这样的形势,在页面上循环打印就行了。

    这样就在页面看到了,那么接下来就是点击相应的publish,显示相应的数据。

    在试图函数中,

    这样filter的功能就实现了。

    然后再实现pop功能,

    当我们点击添加按钮的加号的时候,弹出一个相应的页面,数据添加完后,显示在原来的页面并且弹出的页面关闭。所以,先在页面上渲染加号。

    我们在页面上加了这一行代码:

    但是显示的效果是在每个字段后面都有了+号,这不是我们想要的,我们只想要在有关联其他字段的字段后面添加+号。

    这应该怎么做,我们是否应该判断一下,判断他是多对多字段或者一对多字段的时候,就给他加+号。但是怎么判断呢?

    我们在渲染页面的时候,用的是form表单,但我们知道form表单中的多对多字段和model中的关联字段不一样。

    那应该怎么做呢?

    在addview视图函数中我们先来打印一下字段.field的类型:

    我们看到打印结果:

    我们可以看到打印结果,后面的publish和author字段是分别属于ModelChoiceField和ModelMultipleChoiceField,其实这两者是继承的关系,ModelMultipleChoiceField继承了ModelChoiceField,所以我们只需要判断字段是否属于ModelChoiceField,就能够知道是否属于关联字段了。所以我们这样做,

    在页面上:

    这样在页面上就能得到想要的结果了。加号的渲染就完了。

    然后就是处理点击加号的事情了,我们在添加a标签的时候,有一个onclick事件,那个pop函数的url是那里传过来的呢?肯定是从form里传过来的。所以:

    这样在页面上添加js代码:

    这样当点击加号的时候就能实现弹出一个新的添加页面。

    这个function还需要再传一个参数,

    <script>
        var pop_back_id = '';   //定义一个全局变量,
        function pop(url,id) {
            pop_back_id = id;   //这个值在我们添加完数据在页面上显示的时候会用到
            window.open(url,url,"width=800,height=500,top=100,left=100")
        }
    </script>

     

    然后就该处理数据了。

     现在我们能实现的是我们一点击+号就能弹出来一窗口,然后我们要实现的是添加完数据后,关闭窗口,但是我们知道,可以通过点击+号可以添加数据,也可以通过list_view页面的添加按钮添加数据,那他是怎么判断我们是通过点击+号还是通过按钮添加,所以我们在window.open的时候,在url中传一个参数。

    <script>
        var pop_back_id = '';   //定义一个全局变量,
        function pop(url,id) {
            pop_back_id = id;   //这个值在我们添加完数据在页面上显示的时候会用到
            window.open(url+'?pop=1',url+'?pop=1',"width=800,height=500,top=100,left=100")
        }
    </script>

    这样请求时只需要判断一下request.get能不能拿到pop值,如果能拿到pop,就说明是通过+号添加数据,添加完后可以关闭窗口。

    添加完数据,点击提交所,这是一个post请求。所以在add_view的试图函数中

    返回子页面后,在pop子页面执行js代码关闭窗口。

    然后就是添加数据在页面上显示。同样是在子页面中进行js代码。

    pop子页面的代码就是:

    父页面就是add页面,js代码

    <script>
        var pop_back_id = '';   //定义一个全局变量,
        function pop(url,id) {
            pop_back_id = id;   //这个值在我们添加完数据在页面上显示的时候会用到
            window.open(url+'?pop=1',url+'?pop=1',"width=800,height=500,top=100,left=100")
        }
        function pop_back_func(text,pk) {
            //console.log(text);
            //console.log(pk);
            var $option=$('<option>');
            $option.html(text);
            $option.attr('value',pk);
            $option.attr('selected','selected');
            $('#'+pop_back_id).append($option)    //这个函数是在原来的select标签下添加一个option标签
        }
    </script>
    pop_back_func函数就是实现了在添加数据后,将数据显示在父页面的区域

    这样基本的pop功能就实现了。

     父页面的js代码可以单独写一个js文件。

    然后再add页面和change页面引入。

    接下来就是调bug阶段。

    知识点:

  • 相关阅读:
    【数据操作】存储过程编写经验和优化措施
    【项目管理】产品经理的核心能力模型(译)
    [转] SAP DEVELOPMENT TECHNOLOGY LIST
    【架构设计】五个基本工作流模式(转)
    【工具推荐】Office Open XML
    【经验分享】企业可选的当前主流OA产品
    【项目管理】项目启动阶段 制定项目章程
    【转贴文章】 Dos命令收集
    【架构设计】Web应用程序安全性简介
    [转]what is SAP NetWeaver
  • 原文地址:https://www.cnblogs.com/yb635238477/p/9581324.html
Copyright © 2011-2022 走看看