浅谈Django的Q查询以及AngularJS的Datatables分页插件
来源:互联网 发布:淘宝怎么发布宝贝 编辑:程序博客网 时间:2024/06/05 15:26
使用Q查询,首先要导入Q模块:
from django.db.models import Q
可以组合使用&,|操作符用于多个Q的对象,产生一个新的Q对象,Q对象也可以用~操作符放在前面表示否定,如下例所示:
if search: keywords_list = search.split(' ') query_list = [Q(status__icontains=get_success_fail_status(keyword)) if get_success_fail_keyword_status(keyword) else Q(username__icontains=keyword) | Q(groupid__icontains=keyword) | Q(status_active_vs__icontains=keyword) | Q(orders_created_time__icontains=keyword) | Q(status_bind__icontains=keyword) | Q(status_active_Bind__icontains=keyword) | Q(env__icontains=keyword) for keyword in keywords_list] q = Q() for query in query_list: q.add(query, Q.AND) #把query添加到之前定义的最外层的Q对象中,查询条件是 '和'
其中Q查询里面的 __icontains 表示包含的关系,用于模糊查询,如:
Q(username__icontains=keyword) | Q(groupid__icontains=keyword) 表示查询 username或者 groupid
再谈谈AngularJS的Datatables分页插件:
Datatables的主要功能是分页、即时搜索和排序,虽然django自带的模板引擎也有分页功能(Paginator),但无论从功能上还是美观上,Datatables都更好。
Datatables的效果如下图所示:
下面讲一下Datatables的DTOptionsBuilder方法:
DTOptionsBuilder.newOptions是AngularJS的datatables的一个重要的方法,.newOptions用于实现前后端分页,
DTOptionsBuilder.newOptions() .withOption('ajax', { url: "/api/other/get_http_https_apply/", type: 'GET' }) .withDataProp('data') .withOption('serverSide', true) .withPaginationType('full_numbers') .withOption('createdRow', createdRow) .withOption('order', [ [0, 'desc'] ]);
'serverSide', true 表示开启服务器模式,
ajax表示数据的来源(包括处理分页,排序,过滤),
full_numbers表示所有的数据,
http_https.dtColumns = [ DTColumnBuilder.newColumn('id').withTitle('ID'), DTColumnBuilder.newColumn('username').withTitle('申请人'), DTColumnBuilder.newColumn('env').withTitle('环境'), DTColumnBuilder.newColumn('groupid').withTitle('group_id'), DTColumnBuilder.newColumn('status_active_vs').withTitle('激活vs').renderWith(apply_status), DTColumnBuilder.newColumn('status_bind').withTitle('绑定').renderWith(apply_status), DTColumnBuilder.newColumn('status_active_Bind').withTitle('激活绑定').renderWith(apply_status), DTColumnBuilder.newColumn('status').withTitle('最终结果').renderWith(apply_status), DTColumnBuilder.newColumn('orders_created_time').withTitle('时间') ]; //判断是否是admin用户,如果是admin,则在http_https.dtColumns这个数组中增加(push)一个元素 if (http_https.js_admin) { http_https.dtColumns.push(DTColumnBuilder.newColumn(null).renderWith(actionsHtml).withTitle('Actions')) }
DTColumnBuilder.newColumn表示新增表格的列
.renderWith对数据进行渲染 这里apply_status是我自己写的一个函数,用于转换json中True和False对应的html中的“成功、失败”
部分详情代码请见我的github:https://github.com/a342058040/Django_AngularJS_Datatables.git
0 0
- 浅谈Django的Q查询以及AngularJS的Datatables分页插件
- 浅谈Django的Q查询以及AngularJS的Datatables分页插件
- 浅谈Django的Q查询以及AngularJS的Datatables分页插件
- 浅谈Django的Q查询以及AngularJS的Datatables分页插件
- Django的Q查询
- 带有查询和排序功能的jquery分页插件——DataTables
- Django 的分页插件 django-pagination 使用
- datatables的服务器分页
- Datatables--一个有意思的自动分页和排序的插件
- angularJS服务的$q
- jQuery 的插件 dataTables
- 插件datatables的使用说明
- datatables插件的应用
- DataTables插件分页
- datatables表单分页,国外的
- datatables服务器端分页查询
- datatables服务端分页之带参数查询以及跳页
- AngularJS 的 $q 和 Promise
- JavaScript 设计模式入门和框架中的实践
- scala函数与方法
- 洛谷 1219——[USACO 1.5] 八皇后(深度优先搜索)
- POJ-3673 cow multiplition
- Android Studio与Unity的交互出现的错误
- 浅谈Django的Q查询以及AngularJS的Datatables分页插件
- 服务降级背后的技术架构设计
- 王垠:完全用Linux工作 (转载)
- 高性能高并发系统的稳定性保障
- 使用fetch post json数据的问题
- 分布式服务框架 Zookeeper -- 管理分布式环境中的数据
- java第十天
- 树莓派pi3 串口问题的解决办法
- 修改网口速度mii-tool和ethtool