django之jquery完成ajax
使用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相关推荐
- ajax数据交互代码,Django中使用jquery的ajax进行数据交互的实例代码
jquery框架中提供了$.ajax.$.get.$.post方法,用于进行异步交互,由于Django中默认使用CSRF约束,推荐使用$.get 示例:实现省市区的选择 最终实现效果如图: 将jque ...
- ajax请求必须打断点才能成功,Jquery等待ajax执行完毕继续执行(断点调试正常,运行异常)...
以前写过一个程序,发现用断点调试的时候,一步步的运行,程序是可以的,但是去了断点程序就出现了问题. $(document).ready(function(){ var arra=new Array() ...
- 转: 如何实现jQuery的Ajax文件上传
[PHP文件上传] 在开始之前,我觉得是有必要把通WEB上传文件的原理简单说一下的. 实际上,在这里不管是PHP,JSP,还是ASP处理上传的文件,其实都是WEB早已把文件上传到服务器了,我们只是运用 ...
- 用 jQuery 的 AJAX 功能发现的一个错误/注意点:HTTP Error 411
今天程序中有个地方需要 Ajax 方式 POST 数据,发现在 IE 6.0 下正常,而 FireFox 2.0.0.9 下则出错. 通过 FireBug 抓取 ajax 回发后得到的页面信息如下: ...
- jquery ajax 省 城市 二级菜单 源码,利用了jquery的ajax实现二级联互动菜单
菜单资源保存在数据库中.利用了jquery的ajax实现.用到的包有:json-lib-2.2.3-jdk15.jar ezmorph-1.0.6.jar json.js jquery.js jsp页 ...
- jQuery通过ajax方法获取json数据不执行success的原因及解决方法
1.jquery通过ajax方法获取json数据不执行success回调 问题描述:jquery通过ajax方法获取json数据不执行success回调方法 问题原因:json格式存在问题或不符合标准 ...
- 使用jQuery实现ajax几种方法
一.$.ajax()可以通过发送HTTP请求加载远程数据,是jQuery最底层Ajax实现. 语法 $.ajax({"url" : "UserServlet", ...
- jQuery的ajax使用场景讨论(c#)
一:jQuery.ajax语法基础 jQuery.ajax([options]) 概述:通过 HTTP 请求加载远程数据. jQuery 底层 AJAX 实现.简单易用的高层实现见 $.get, $. ...
- 为jQuery的$.ajax设置超时时间
jQuery的ajax模块封装了非常强大的功能,有时候我们在发送一个ajax请求的时候希望能有一个超时的时间,想让程序在一段时间请求不到数据时做出一些反馈.幸运的是jQuery为我们提供了这样的参数: ...
最新文章
- python3.8.5 run-Python 3.8.5 正式发布
- SDM管理路由器要进行的相应配置
- 终端如何粘贴快捷键_你有什么喜欢的 Linux 终端技巧?
- OutOfMemoryException异常解析
- 小程序确定取消弹窗_小程序开发之弹出框
- R 包的安装,使用,更新
- 通过代理上网 固定ip_浅析局部代理IP与全局代理IP的使用说明
- JeecgBoot低代码平台 2.4.5 版本发布,钉钉与企业微信集成版本
- windows下使用kafka
- 渗透工具—反制爬虫之Burp Suite RCE
- pd虚拟机:mac支持安装Windows应用
- 扒一个超棒的stm32的开源usb-can项目,canable及PCAN固件
- Gif动图体积如何缩小?分享一招快速压缩动图的方法
- mac jupyter notebook 服务似乎挂掉了,但是会立刻重启的
- 快门光圈感光度口诀_一张图教你看懂相机光圈、快门、感光度!太神了!
- vscode 编写html 浏览器显示 空白 白屏
- RK3288 资源汇总
- 使用Windows Server 2003实现高可用故障转移群集(1)
- 笨方法学python 42课笔记:物以类聚
- 基于神经网络的语音频带扩展
热门文章
- go语言离线查看说明文档
- linux-内核启动流程分析
- 【CyberSecurityLearning 50】JS 基础+函数+对象+事件
- NASM 中 SECTION 的默认对齐
- Spring Cache
- zcmu-1181(大数相加)
- Guide To Using The Gnosis Multisig Wallet
- [Android]你不知道的Android进程化(2)--创建进程
- 动手编写一个以太坊智能合约
- Android7.0 PowerManagerService(1) 启动过程