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实现文件名批量替换和内容替换
Mar 20 Python
解决python中 f.write写入中文出错的问题
Oct 31 Python
python使用PIL实现多张图片垂直合并
Jan 15 Python
浅谈python新式类和旧式类区别
Apr 26 Python
python实现微信机器人: 登录微信、消息接收、自动回复功能
Apr 29 Python
python使用PIL和matplotlib获取图片像素点并合并解析
Sep 10 Python
PyTorch预训练的实现
Sep 18 Python
Django后端发送小程序微信模板消息示例(服务通知)
Dec 17 Python
Eclipse配置python默认头过程图解
Apr 26 Python
opencv+pyQt5实现图片阈值编辑器/寻色块阈值利器
Nov 13 Python
Pandas的数据过滤实现
Jan 15 Python
pycharm 如何查看某一函数源码的快捷键
May 12 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
玩转图像函数库―常见图形操作
2006/09/03 PHP
php下连接ftp实现文件的上传、下载、删除文件实例代码
2010/06/03 PHP
PHP 登录记住密码实现思路
2013/05/07 PHP
使用array mutisort 实现按某字段对数据排序
2013/06/18 PHP
php不用正则验证真假身份证
2013/11/06 PHP
Iframe自适应高度绝对好使的代码 兼容IE,遨游,火狐
2011/01/27 Javascript
javascript中的toFixed固定小数位数 简单实例分享
2013/07/12 Javascript
Jquery动态进行图片缩略的原理及实现
2013/08/13 Javascript
详解JavaScript中undefined与null的区别
2014/03/29 Javascript
通过url查找a元素应用案例
2014/04/29 Javascript
jquery获得当前html页面源码的方法
2015/07/14 Javascript
jQuery时间轴插件使用详解
2015/07/16 Javascript
谈谈基于iframe、FormData、FileReader三种无刷新上传文件的方法
2015/12/03 Javascript
React Native实现简单的登录功能(推荐)
2016/09/19 Javascript
教你一步步用jQyery实现轮播器
2016/12/18 Javascript
详解有关easyUI的拖动操作中droppable,draggable用法例子
2017/06/03 Javascript
使用Bootrap和Vue实现仿百度搜索功能
2017/10/26 Javascript
vue通过style或者class改变样式的实例代码
2018/10/30 Javascript
详解使用WebPack搭建React开发环境
2019/08/06 Javascript
浅谈layer弹出层按钮颜色修改方法
2019/09/11 Javascript
JS删除数组指定值常用方法详解
2020/06/04 Javascript
python 获取et和excel的版本号
2009/04/09 Python
Python中的类学习笔记
2014/09/23 Python
PyCharm设置每行最大长度限制的方法
2019/01/16 Python
Python多线程处理实例详解【单进程/多进程】
2019/01/30 Python
pytorch多GPU并行运算的实现
2019/09/27 Python
Django后端按照日期查询的方法教程
2021/02/28 Python
澳大利亚汽车零部件、音响及配件超市:Automotive Superstore
2018/06/19 全球购物
三年级语文教学反思
2014/02/01 职场文书
个人批评与自我批评发言稿
2014/09/28 职场文书
师德师风事迹材料
2014/12/20 职场文书
小学教师师德师风自我评价
2015/03/04 职场文书
“学党章、守党纪、讲党规”学习心得体会
2016/01/14 职场文书
sql查询结果列拼接成逗号分隔的字符串方法
2021/05/25 SQL Server
在Python中如何使用yield
2021/06/07 Python
Spring-cloud Config Server的3种配置方式
2021/09/25 Java/Android