Ajax请求的几个小练习

准备工作

路由中做了分发:
re_path('^app01/',include('app01.url'))
app01中url.py文件的内容:
from django.urls import re_path
from app01 import views urlpatterns = [
re_path('^index/$',views.index),
re_path('^test_ajax/$',views.test_ajax),
re_path('^cal/$',views.cal),
re_path('^login/$',views.login),
]
视图函数中第一条进入首页的函数
def index(request):
return render(request,'index.html')
models.py文件中新增一张数据表user:
class User(models.Model):
name = models.CharField(max_length=32)
pwd = models.CharField(max_lenngth=32)

几个请求的小练习

以下只写app01应用的views与templates的模板文件的js代码——static文件的引入略去——大家注意写js前一定要先引入jQuery

点击按钮令下面的标签出现后台传送的文字

标签如下:
<button class='AJAX'>AJAX</button>
<p class='content'></p>
js内容如下:
   $('.AJAX').click(function{
//发送ajax请求
$.ajax({
//请求的url,需要增加路由
//做了分发,路径要相应改一下
url:'app01/test_ajax',
type:'post',
data:{a:1,b:2},
success:function(data){
console.log(data)
//局部刷新
$('.content').html(data)
}
})
})
视图函数内容如下:
def test_ajax(request):
print(request.GET) #<QueryDict: {'a': ['1'], 'b': ['2']}>
return HttpResponse('OK!')

Ajax计算求和练习

标签如下:
<input id='n1' type='text'> + <input id='n2' type='text'> = <input id='n3' type='text'>
<input type='button' id='cal' value='计算'>
js内容如下:
  $('#cal').click(function(){

		$.ajax({
//计算的url,需要增加路由
//做了分发,路径要相应改一下
url:'/app01/cal/',
type:'post',
data:{
'n1':$('#n1').val(),
'n2':$('#n2').val()
},
//注意这里得加形参data,接收视图函数传过来的值
success:function(data){
//结果赋值
console.log(data)
$('#n3').val(data)
}
})
})
视图函数内容如下:
def cal(request):
print(request.POST) #<QueryDict: {'n1': ['1232'], 'n2': ['123']}>
n1 = int(request.POST.get('n1'))
n2 = int(request.POST.get('n2'))
ret = n1 + n2
return HttpRequest(ret)

Ajax登陆验证

标签如下:
<form action=''>
用户名: <input id='user' type='text'>
密 码: <input id='pwd' type='text'>
<input id='login_btn' type='button' value='确认'>
<span id='error'></span>
</form>
js内容如下:
  $('#login_btn').click(function{
$.ajax({
//增加路由,注意分发的写法
url:'/app01/login/',
type:'post',
data:{
'user':$('#user').val(),
'pwd':$('#pwd').val()
},
success:function(data){
console.log(data) //得到的是json字符串 {"user": null, "msg": "wrong username or password"}
console.log(typeof data) //string类型
//反序列化
var dt = JSON.parse(data) //得到的是 object{}
console.log(dt) //{"user": null, "msg": "wrong username or password"}
console.log(typeof dt) //object
//注意下面对象调用了dt
if(dt.user){
location.href='http://www.baidu.com'
}
else{
$('#error').html(dt.msg).css({'color':'red','margin-left':'10px'})
}
},
})
})
视图函数内容如下:
def login(request):
print(request.POST) #<QueryDict: {'user': ['123'], 'pwd': ['222']}>
username = request.POST.get('user')
password = request.POST.get('pwd')
#返回的信息
ret = {'user':None,'msg':None}
##从数据库中找值去判断————注意数据库中的字段是name与pwd,还有这里要用first()
user = User.objects.filter(name=username,pwd=password).first()
if user:
ret['user'] = user.name
else:
ret['pwd'] = 'wrong username or password'
#给前端返回序列化后的数据
import json
return HttpRequest(json.dumps(ret))

效果演示:

Ajax请求的几个小练习的更多相关文章

  1. Ajax请求,跨域小坑

    今天在上班的时候,被坐在旁边项目经理叫过去问了一个Ajax请求跨域的问题,一开始没理解清楚也还有对这个没有理解的透,后面被打击的要死. 当时的需求是需要测试一个已发布的api接口,需要在本地写测试程序 ...

  2. javascrpt 中的Ajax请求

    回顾下javascript中的Ajax请求,写一个小例子: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN& ...

  3. python学习(26)分析ajax请求抓取今日头条cosplay小姐姐图片

    分析ajax请求格式,模拟发送http请求,从而获取网页代码,进而分析取出需要的数据和图片.这里分析ajax请求,获取cosplay美女图片. 登陆今日头条,点击搜索,输入cosplay 下面查看浏览 ...

  4. JQuery ajax请求struts action实现异步刷新的小实例

    这个样例是用JQuery ajax和struts来做的一个小样例,在这个样例中采用两种方式将java Util中的list转换成支json的格式,第一种是用json-lib.jar这个jar包来转换, ...

  5. AJAX请求详解 同步异步 GET和POST

    AJAX请求详解 同步异步 GET和POST 上一篇博文(http://www.cnblogs.com/mengdd/p/4191941.html)介绍了AJAX的概念和基本使用,附有一个小例子,下面 ...

  6. 原生js发送ajax请求

    堕落了一阵子了,今天打开博客,发现连登录的用户名和密码都不记得了.2016年已过半,不能再这么晃荡下去了. 参加了网易微专业-前端攻城狮 培训,目前进行到大作业开发阶段,感觉举步维艰.但是无论如何,不 ...

  7. 怎样防止重复发送 Ajax 请求?

    著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处.作者:长天之云链接:http://www.zhihu.com/question/19805411/answer/15465427来源 ...

  8. 采用指数退避算法实现ajax请求的重发,全部完成时触发回调函数

    目录: 0.Chrome扩展开发(Gmail附件管理助手)系列之〇——概述 1.Chrome扩展开发之一——Chrome扩展的文件结构 2.Chrome扩展开发之二——Chrome扩展中脚本的运行机制 ...

  9. ajax请求总是不成功?浏览器的同源策略和跨域问题详解

    场景 码农小明要做一个展示业务数据的大屏给老板看,里面包含了来自自己网站的数据和来自隔壁老王的数据.那么自己网站的数据提供了 http://xiaoming.com/whoami 这样的数据接口隔壁老 ...

随机推荐

  1. Hadoop 2.7.4 HDFS+YRAN HA部署

    实验环境 主机名称 IP地址 角色 统一安装目录 统一安装用户 sht-sgmhadoopnn-01 172.16.101.55 namenode,resourcemanager /usr/local ...

  2. FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask. MetaException(me

    FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask. MetaException(me ...

  3. html5(八) IndexedDB

    IndexedDB 是一个数据库系统,它在用户的计算机上存储索引信息. IndexedDB与传统的数据库不同.在IndexedDB中,数据库中的信息以对象的形式存储在对象库表中.对象库没有特定的结构, ...

  4. RandomAccessFile多线程下载

    public class DownloadServer { ; private static String fileUrl = "https://dldir1.qq.com/qqtv/mac ...

  5. STL 小白学习(5) stack栈

    #include <iostream> #include <stack> //stack 不遍历 不支持随机访问 必须pop出去 才能进行访问 using namespace ...

  6. python中字符串格式化

    username='小黑'age=18high=1.88s2='欢迎%s,年龄是%d,身高是%.2f'%(username,age,high)#%s是通用的,%d就必须传整数,%f就必须是小数,想保留 ...

  7. SqlServer根据表中ID加序号

    正序列号select ROW_NUMBER() over(order by Id) as xh,Id,Name,TelNumber,Zhijin from Users1 反序列号select 序号=( ...

  8. tar 命令 简易使用方法

    创建压缩文件方法 tar zcf 压缩包存放位置 压缩那个目录/内容 (压缩) 例:在/data目录下压缩/etc/目录,并创建名称为etc.tar.gz [root@web01 /]# tar zc ...

  9. layui布局器网站工具

    http://layuiout.magicalcoder.com/magicaldrag-admin/drag

  10. java 几种对象

     POJO(plain old java object):普通的java对象,有别于特殊的java对象(含继承约束等)和EJB.POJO一般只有一系列的属性和相应的get.set方法.     PO( ...