使用Ajax

  • 使用视图通过上下文向模板中传递数据,需要先加载完成模板的静态页面,再执行模型代码,生成最张的html,返回给浏览器,这个过程将页面与数据集成到了一起,扩展性差
  • 改进方案:通过ajax的方式获取数据,通过dom操作将数据呈现到界面上
  • 推荐使用框架的ajax相关方法,不要使用XMLHttpRequest对象,因为操作麻烦且不容易查错
  • jquery框架中提供了$.ajax、$.get、$.post方法,用于进行异步交互
  • 由于csrf的约束,推荐使用$.get
  • 示例:实现省市区的选择
  • 最终实现效果如图:

引入js文件

  • js文件属于静态文件,创建目录结构如图:

修改settings.py关于静态文件的设置

STATIC_URL = '/static/'
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static'),
]

在models.py中定义模型

class AreaInfo(models.Model):aid = models.IntegerField(primary_key=True)atitle = models.CharField(max_length=20)aPArea = models.ForeignKey('AreaInfo', null=True)

生成迁移

python manage.py makemigrations
python manage.py migrate

通过workbench向表中填充示例数据

  • 参见“省市区.sql”
  • 注意将表的名称完成替换

在views.py中编写视图

  • index用于展示页面
  • getArea1用于返回省级数据
  • getArea2用于根据省、市编号返回市、区信息,格式都为字典对象
from django.shortcuts import render
from django.http import JsonResponse
from models import AreaInfodef index(request):return render(request, 'ct1/index.html')def getArea1(request): list = AreaInfo.objects.filter(aPArea__isnull=True) list2 = [] for a in list: list2.append([a.aid, a.atitle]) return JsonResponse({'data': list2}) def getArea2(request, pid): list = AreaInfo.objects.filter(aPArea_id=pid) list2 = [] for a in list: list2.append({'id': a.aid, 'title': a.atitle}) return JsonResponse({'data': list2}) 

在urls.py中配置urlconf

from django.conf.urls import url
from . import viewsurlpatterns = [url(r'^$', views.index),url(r'^area1/$', views.getArea1),url(r'^([0-9]+)/$', views.getArea2), ]

主urls.py中包含此应用的url

from django.conf.urls import include, url
from django.contrib import adminurlpatterns = [url(r'^', include('ct1.urls', namespace='ct1')),url(r'^admin/', include(admin.site.urls)),
]

定义模板index.html

  • 在项目中的目录结构如图:

  • 修改settings.py的TEMPLATES项,设置DIRS值
'DIRS': [os.path.join(BASE_DIR, 'templates')],

  • 定义模板文件:包含三个select标签,分别存放省市区的信息
<!DOCTYPE html>
<html>
<head><title>省市区列表</title>
</head>
<body>
<select id="pro"><option value="">请选择省</option>
</select>
<select id="city"><option value="">请选择市</option>
</select>
<select id="dis"><option value="">请选择区县</option>
</select>
</body>
</html> 

在模板中引入jquery文件

<script type="text/javascript" src="static/ct1/js/jquery-1.12.4.min.js"></script>

编写js代码

  • 绑定change事件
  • 发出异步请求
  • 使用dom添加元素
<script type="text/javascript">$(function(){$.get('area1/',function(dic) {pro=$('#pro')$.each(dic.data,function(index,item){pro.append('<option value='+item[0]+'>'+item[1]+'</option>');})});$('#pro').change(function(){$.post($(this).val()+'/',function(dic){ city=$('#city'); city.empty().append('<option value="">请选择市</option>'); $.each(dic.data,function(index,item){ city.append('<option value='+item.id+'>'+item.title+'</option>'); }) }); }); $('#city').change(function(){ $.post($(this).val()+'/',function(dic){ dis=$('#dis'); dis.empty().append('<option value="">请选择区县</option>'); $.each(dic.data,function(index,item){ dis.append('<option value='+item.id+'>'+item.title+'</option>'); }) }) }); }); </script>

转载于:https://www.cnblogs.com/alexzhang92/p/9529787.html

django之jquery完成ajax相关推荐

  1. ajax数据交互代码,Django中使用jquery的ajax进行数据交互的实例代码

    jquery框架中提供了$.ajax.$.get.$.post方法,用于进行异步交互,由于Django中默认使用CSRF约束,推荐使用$.get 示例:实现省市区的选择 最终实现效果如图: 将jque ...

  2. ajax请求必须打断点才能成功,Jquery等待ajax执行完毕继续执行(断点调试正常,运行异常)...

    以前写过一个程序,发现用断点调试的时候,一步步的运行,程序是可以的,但是去了断点程序就出现了问题. $(document).ready(function(){ var arra=new Array() ...

  3. 转: 如何实现jQuery的Ajax文件上传

    [PHP文件上传] 在开始之前,我觉得是有必要把通WEB上传文件的原理简单说一下的. 实际上,在这里不管是PHP,JSP,还是ASP处理上传的文件,其实都是WEB早已把文件上传到服务器了,我们只是运用 ...

  4. 用 jQuery 的 AJAX 功能发现的一个错误/注意点:HTTP Error 411

    今天程序中有个地方需要 Ajax 方式 POST 数据,发现在 IE 6.0 下正常,而 FireFox 2.0.0.9 下则出错. 通过 FireBug 抓取 ajax 回发后得到的页面信息如下: ...

  5. jquery ajax 省 城市 二级菜单 源码,利用了jquery的ajax实现二级联互动菜单

    菜单资源保存在数据库中.利用了jquery的ajax实现.用到的包有:json-lib-2.2.3-jdk15.jar ezmorph-1.0.6.jar json.js jquery.js jsp页 ...

  6. jQuery通过ajax方法获取json数据不执行success的原因及解决方法

    1.jquery通过ajax方法获取json数据不执行success回调 问题描述:jquery通过ajax方法获取json数据不执行success回调方法 问题原因:json格式存在问题或不符合标准 ...

  7. 使用jQuery实现ajax几种方法

    一.$.ajax()可以通过发送HTTP请求加载远程数据,是jQuery最底层Ajax实现. 语法 $.ajax({"url" : "UserServlet", ...

  8. jQuery的ajax使用场景讨论(c#)

    一:jQuery.ajax语法基础 jQuery.ajax([options]) 概述:通过 HTTP 请求加载远程数据. jQuery 底层 AJAX 实现.简单易用的高层实现见 $.get, $. ...

  9. 为jQuery的$.ajax设置超时时间

    jQuery的ajax模块封装了非常强大的功能,有时候我们在发送一个ajax请求的时候希望能有一个超时的时间,想让程序在一段时间请求不到数据时做出一些反馈.幸运的是jQuery为我们提供了这样的参数: ...

最新文章

  1. python3.8.5 run-Python 3.8.5 正式发布
  2. SDM管理路由器要进行的相应配置
  3. 终端如何粘贴快捷键_你有什么喜欢的 Linux 终端技巧?
  4. OutOfMemoryException异常解析
  5. 小程序确定取消弹窗_小程序开发之弹出框
  6. R 包的安装,使用,更新
  7. 通过代理上网 固定ip_浅析局部代理IP与全局代理IP的使用说明
  8. JeecgBoot低代码平台 2.4.5 版本发布,钉钉与企业微信集成版本
  9. windows下使用kafka
  10. 渗透工具—反制爬虫之Burp Suite RCE
  11. pd虚拟机:mac支持安装Windows应用
  12. 扒一个超棒的stm32的开源usb-can项目,canable及PCAN固件
  13. Gif动图体积如何缩小?分享一招快速压缩动图的方法
  14. mac jupyter notebook 服务似乎挂掉了,但是会立刻重启的
  15. 快门光圈感光度口诀_一张图教你看懂相机光圈、快门、感光度!太神了!
  16. vscode 编写html 浏览器显示 空白 白屏
  17. RK3288 资源汇总
  18. 使用Windows Server 2003实现高可用故障转移群集(1)
  19. 笨方法学python 42课笔记:物以类聚
  20. 基于神经网络的语音频带扩展

热门文章

  1. go语言离线查看说明文档
  2. linux-内核启动流程分析
  3. 【CyberSecurityLearning 50】JS 基础+函数+对象+事件
  4. NASM 中 SECTION 的默认对齐
  5. Spring Cache
  6. zcmu-1181(大数相加)
  7. Guide To Using The Gnosis Multisig Wallet
  8. [Android]你不知道的Android进程化(2)--创建进程
  9. 动手编写一个以太坊智能合约
  10. Android7.0 PowerManagerService(1) 启动过程