Django 使用Ajax进行前后台交互的示例讲解


Posted in Python onMay 28, 2018

本文要实现的功能是:根据下拉列表的选项将数据库中对应的内容显示在页面,选定要排除的选项后,提交剩余的选项到数据库。

为了方便前后台交互,利用了Ajax的GET和POST方法分别进行数据的获取和提交。

代码如下:

<!--利用获取的数据进行表单内容的填充-->
<script>
$("#soft_id").change(function(){
var softtype=$("#soft_id").find("option:selected").text();
var soft={'type_id':softtype}
$.ajax( {
 type: 'GET',
 url:'/data/soft-filter/{{family}}',
 dataType: 'json',
 data:soft,
 success: function( data_get ){
 build_dropdown( data_get, $( '#min_version' ), '请选择最低版本' );//填充表单
 build_dropdown( data_get, $( '#max_version' ), '请选择最高版本' );
 build_div(data_get,$('#soft_affected'));
 }
 }); 
 });
 var build_dropdown = function( data, element, defaultText ){
 element.empty().append( '<option value="">' + defaultText + '</option>' );
 if( data ){
 $.each( data, function( key, value ){
 element.append( '<option value="' + key + '">' + value + '</option>' );
 } );
 }
 }
 var build_div = function( data, element){
 if( data ){
 element.empty();
 $.each( data, function( key, value ){
  element.append(' <li class="clearfix"> <div class="todo-check pull-left"><input name="chk" type="checkbox" value="'+value+'" /></div> <div class="todo-title">'+value+' </div><div class="todo-actions pull-right clearfix"><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="todo-complete"><i class="fa fa-check"></i></a><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="todo-edit"><i class="fa fa-edit"></i></a><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="todo-remove"><i class="fa fa-trash-o"></i></a></div> </li>');
 } );
 }
}
</script>
<!--选择并提交数据-->
<script>
//选择数据
function postselect (){
  var seleitem=new Array();
 $("input[name='chk']").each(function(i){
 if(!($(this).is( ":checked" )) ){
  seleitem[i]=$(this).val();
  // alert(seleitem[i]); 
}
});
//将排除后的数据提交到后台数据库
var soft={'type_id':seleitem}
$.ajax( {
 type: 'POST',
 url:'/data/soft-submit',
 dataType: 'json',
 data:soft,
 success: function( data_get ){
 }
 });
}
</script>

部分html代码为:

<div style="overflow: hidden;" >
      <ul id='soft_affected' class="todo-list sortable">
      </ul>
 </div>

views.py中处理请求和响应代码:

def soft_submit(request):
 if request.is_ajax():
  id=request.POST.get('type_id')
 return HttpResponse("success")
def soft_filter(request,fami):
 softtype=''
 ajax_release_version=[]
 release_version=[]
 if request.is_ajax():
  softtype=request.GET.get('type_id')
  soft_type=SoftTypeRef.objects.using('vul').filter(description=softtype)
  soft_tp_id=0
  for i in soft_type:
   soft_tp_id= i.soft_type_id
  web_soft=SoftWeb.objects.using('vul').filter(soft_type_id=soft_tp_id)
  for i in web_soft:
   ajax_release_ver=i.release_version
   ajax_release_version.append(ajax_release_ver)
  return HttpResponse(json.dumps(ajax_release_version), content_type='application/json')

以上这篇Django 使用Ajax进行前后台交互的示例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python获取多线程及子线程的返回值
Nov 15 Python
pytorch + visdom 处理简单分类问题的示例
Jun 04 Python
python pandas 对时间序列文件处理的实例
Jun 22 Python
详解python 注释、变量、类型
Aug 10 Python
使用 Python 实现简单的 switch/case 语句的方法
Sep 17 Python
pycharm: 恢复(reset) 误删文件的方法
Oct 22 Python
selenium3+python3环境搭建教程图解
Dec 07 Python
python使用插值法画出平滑曲线
Dec 15 Python
python集成开发环境配置(pycharm)
Feb 14 Python
Pandas的Apply函数具体使用
Jul 21 Python
解决python存数据库速度太慢的问题
Apr 23 Python
python 利用PyAutoGUI快速构建自动化操作脚本
May 31 Python
Python实现爬虫爬取NBA数据功能示例
May 28 #Python
Django+Ajax+jQuery实现网页动态更新的实例
May 28 #Python
Python实现合并两个列表的方法分析
May 28 #Python
django js实现部分页面刷新的示例代码
May 28 #Python
Django项目中用JS实现加载子页面并传值的方法
May 28 #Python
Python面向对象类继承和组合实例分析
May 28 #Python
django传值给模板, 再用JS接收并进行操作的实例
May 28 #Python
You might like
PHP学习笔记 (1) 环境配置与代码调试
2011/06/19 PHP
php5.3 不支持 session_register() 此函数已启用的解决方法
2013/11/12 PHP
PHP实现数字补零功能的2个函数介绍
2014/05/12 PHP
学习php设计模式 php实现合成模式(composite)
2015/12/08 PHP
PHP的PDO事务与自动提交
2019/01/24 PHP
Javascript中eval函数的使用方法与示例
2007/04/09 Javascript
Ext grid 添加右击菜单
2009/11/26 Javascript
Jquery ajax不能解析json对象,报Invalid JSON错误的原因和解决方法
2010/03/27 Javascript
有关json_decode乱码及NULL的问题
2015/10/13 Javascript
Javascript字符串常用方法详解
2016/07/21 Javascript
微信小程序 swiper组件详解及实例代码
2016/10/25 Javascript
实现jquery放大镜的两种方法
2018/02/22 jQuery
Angular4 ElementRef的应用
2018/02/26 Javascript
vue限制输入框只能输入8位整数和2位小数的代码
2019/11/06 Javascript
JS实现的雪花飘落特效示例
2019/12/03 Javascript
JavaScript将数组转换为链表的方法
2020/02/16 Javascript
Python struct.unpack
2008/09/06 Python
python发送arp欺骗攻击代码分析
2014/01/16 Python
python文件名和文件路径操作实例
2017/09/29 Python
python对日志进行处理的实例代码
2018/10/06 Python
python命令行工具Click快速掌握
2019/07/04 Python
PyQT5 emit 和 connect的用法详解
2019/12/13 Python
pycharm内无法import已安装的模块问题解决
2020/02/12 Python
html5教程调用绘图api画简单的圆形代码分享
2013/12/04 HTML / CSS
英国殿堂级有机护肤品牌:Rodial
2017/04/17 全球购物
麦德龙官方海外旗舰店:德国麦德龙超市
2017/12/23 全球购物
使用useBean标志初始化BEAN时如何接受初始化参数
2012/02/11 面试题
专业毕业生个性的自我评价
2013/10/03 职场文书
小学生美德少年事迹
2014/02/02 职场文书
小学二年级学生评语
2014/04/21 职场文书
2014物价局民主生活会对照检查材料思想汇报
2014/09/24 职场文书
2014年流动人口工作总结
2014/11/26 职场文书
2015年党风廉政建设责任书
2015/01/29 职场文书
表扬信范文
2015/05/04 职场文书
反邪教学习心得体会
2016/01/15 职场文书
详解Java实现设计模式之责任链模式
2021/06/23 Java/Android