django 支持ajax6,(2018-05-14.Python从Zero到One)6、(Django)Django高级__1.5.6使用Ajax

使用Ajax

使用视图通过上下文向模板中传递数据,需要先加载完成模板的静态页面,再执行模型代码,生成最张的html,返回给浏览器,这个过程将页面与数据集成到了一起,扩展性差

改进方案:通过ajax的方式获取数据,通过dom操作将数据呈现到界面上

推荐使用框架的ajax相关方法,不要使用XMLHttpRequest对象,因为操作麻烦且不容易查错

jquery框架中提供了$.ajax、$.get、$.post方法,用于进行异步交互

由于csrf的约束,推荐使用$.get

示例:实现省市区的选择

最终实现效果如图:

95d07da4a454

day48_Django高级-01.gif

引入js文件

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

95d07da4a454

day48_Django高级-01.png

修改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 AreaInfo

def 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 views

urlpatterns = [

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 admin

urlpatterns = [

url(r'^', include('ct1.urls', namespace='ct1')),

url(r'^admin/', include(admin.site.urls)),

]

定义模板index.html

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

95d07da4a454

day48_Django高级-02.png

修改settings.py的TEMPLATES项,设置DIRS值

'DIRS': [os.path.join(BASE_DIR, 'templates')],

定义模板文件:包含三个select标签,分别存放省市区的信息

省市区列表

请选择省

请选择市

请选择区县

在模板中引入jquery文件

编写js代码

绑定change事件

发出异步请求

使用dom添加元素

$(function(){

$.get('area1/',function(dic) {

pro=$('#pro')

$.each(dic.data,function(index,item){

pro.append(''+item[1]+'');

})

});

$('#pro').change(function(){

$.post($(this).val()+'/',function(dic){

city=$('#city');

city.empty().append('请选择市');

$.each(dic.data,function(index,item){

city.append(''+item.title+'');

})

});

});

$('#city').change(function(){

$.post($(this).val()+'/',function(dic){

dis=$('#dis');

dis.empty().append('请选择区县');

$.each(dic.data,function(index,item){

dis.append(''+item.title+'');

})

})

});

});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值