Ajax简介

Ajax 即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML),是指一种创建交互式网页应用的网页开发技术。
Ajax = 异步 JavaScript 和 XML标准通用标记语言的子集)。
Ajax 是一种用于创建快速动态网页的技术。
Ajax 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。
通过在后台与服务器进行少量数据交换,Ajax 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。
传统的网页(不使用 Ajax)如果需要更新内容,必须重载整个网页页面。
 

向服务器发送请求的方式

1、浏览器地址栏,默认get 请求

2、form表单:

  get请求

  post请求

3、a标签,默认get请求

4、Ajax

  get请求

  post请求

 特点:

   1、异步请求

   2、局部刷新

Ajax简单应用

1、首先先创建一个简单的django项目

urls.py

from django.contrib import admin
from django.urls import path
from app01 import views
urlpatterns = [
path('admin/', admin.site.urls),
path('index/',views.index),
path('test_ajax/',views.ajax)
]

views.py

from django.shortcuts import render,HttpResponse
def index(request):
return render(request,'index.html') # Create your views here.
def ajax(request):
return HttpResponse('ok')

templates/index.html


<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
</head>
<body>
<h1>index</h1>
<button class="Ajax">Ajax</button>
<p class="content"></p>
<script>
$('.Ajax').click(function () {
alert('123')#
//发送Ajax请求
$.ajax({
url:'/test_ajax/',//请求url
type:'get',//请求方式 post
//data:{},#请求数据
success:function (data) {//回调函数,某个动作执行完之后执行的函数
console.log(data);
$('.content').html(data)

}
})

})
</script>
</body>
</html>
 

2、以上代码实现效果

当我们访问 index的时候

等我们在点击Ajax按钮的时候

这里到底发生了什么

访问流程

1、首先咱们访问index,是一次get请求。

2、当我们点击Ajax按钮的时候,这里触发了 模板里写好的函数,Ajax去请求url

    $('.Ajax').click(function () {
alert('123')
//发送Ajax请求
$.ajax({
url:'/test_ajax/',//请求url
type:'get',//请求方式 post

3、请求url得到在试图函数中写好的逻辑,返回了‘ok’值,这里data接收了这个值

进行前端日志打印,和给 ‘content’添加html的值。

success:function (data) {//回调函数,某个动作执行完之后执行的函数
console.log(data);
$('.content').html(data)

4、此次请求没有刷新页面,url没有改变,只是进行了局部的刷新,对p标签进行赋值。

Ajax计算器

刚刚说过Ajax 可以发送 get 请求与post 请求,这次计算器就用到post请求,直接上代码

index.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
</head>
<body>
<h1>index</h1>
<input id="num1" type="number">+<input id="num2" type="number">=<input id="result" type="number"><button class="cal">计算</button>
<script>
$('.cal').click(function () {
//发送Ajax请求
$.ajax({
url:'/ual/',//请求url
type:'post',//请求方式 post
data:{
'n1':$('#num1').val(),//获取用户输入值并赋值给n1,通过post请求发送给 'ual'
'n2':$('#num2').val(),
},//请求数据
success:function(data){//回调函数,某个动作执行完之后执行的函数
$('#result').val(data);
console.log(data); }
}) })
</script>
</body>
</html>

views.py

from django.shortcuts import render,HttpResponse
def index(request):
return render(request,'index.html') # Create your views here.
def ajax(request):
print(request.GET)
return HttpResponse('ok')
def ual(request):
print(request.POST)
n1 = int(request.POST.get('n1')) #获取传递过来的变量,并取值
n2 = int(request.POST.get('n2'))
ret =n1+n2 #相加操作
return HttpResponse(ret) #返回结果给模板。

urls.py

from django.contrib import admin
from django.urls import path
from app01 import views
urlpatterns = [
path('admin/', admin.site.urls),
path('index/',views.index),
path('test_ajax/',views.ajax),
path('ual/',views.ual),
]

#注意,这里需要先在settings.py 中注释掉 csrf相关行,后面验证会说道。不然前端页面无法正常显示。

效果

这里的步骤相对于上面的get请求的是,Ajax发送post请求给后端试图,后端服务器进行计算操作,将值传递给模板进行显示。

登录验证

大概思路

1、前端获取用户输入信息

2、通过ajax传给后端服务器

3、后端服务器通过orm 调用数据库信息对前端接受信息进行验证

4、验证过后因为 HttpResponse() 只返回字符串,这里就用到之前学到对json 序列化,将验证结果序列化后返回给前端模版

5、模版将字符串反序列化,变成js对象,这里要注意跟python内部序列化和反序列化有一定不通,这里是跨语言传输

6、前端通过逻辑判断用户是否正确反馈给用户。

下面开始上菜

这里就不啰嗦了,直接开始从模版开始

index.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="http://ajax.aspnetcdn.com/ajax/jquery/jquery-2.1.4.min.js"></script>
</head>
<body>
<form >
用户名<input type="text" id="user">
密码<input type='password' id="pwd">
<input type="button" value="submit" class="login_btn"><span class="error"></span>
</form>
<script>
//登录验证
$(".login_btn").click(function(){ $.ajax({
url:"/login/",//请求url
type:"post",
data:{
"user":$("#user").val(),//获取用户输入
"pwd":$("#pwd").val(),
},
success:function(data){
console.log(data);
var data=JSON.parse(data); //反序列化 object {}
console.log(data);//json 字符串
if (data.user){ //判断是否有值
location.href='http://www.baidu.com' //登录成功后跳转页面,这个应该是跳转到自己到程序页面,这里用百度先代替一下 }
else{
$('.error').html(data.msg).css({"color":"red","margin-left":"10px"}) //判断失败后在前端页面显示错误信息
} } }) })
</script> </body>
</html>

url.py

from django.contrib import admin
from django.urls import path
from app01 import views
urlpatterns = [
path('admin/', admin.site.urls),
path('index/',views.index),
path('login/',views.login),
]

views.py

from django.shortcuts import render,HttpResponse
from app01.models import * # Create your views here.
def index(request): return render(request,'index.html')
def login(request):
print(request.POST)
  #获取post信息
user=request.POST.get('user')
pwd=request.POST.get('pwd')
  #查询数据库该内容是否存在  
ret = Users.objects.filter(user=user,pwd=pwd).first()  #这里如果存在就会返回一个对象,否则返回None
  
ret_dict = {'user':None,'msg':None} #这里生成一个字典,放置需要传递给前端的数据,也为了进行序列化操作
  #根据查询结果对字典内容进行修改
if ret:
ret_dict['user'] = user
else:
ret_dict['msg'] = 'user or password error ' import json
return HttpResponse(json.dumps(ret_dict)) #序列还传给前端

这里models.py  就不写了,如果不会对小伙伴可以参考我以前对博客

最终效果

登录成功

后端输出

<QueryDict: {'user': ['liu'], 'pwd': ['123']}>
Users object (1)
[28/Nov/2018 15:01:43] "POST /login/ HTTP/1.1" 200 28

前端直接跳转到指定页面

登录失败

后端输出

<QueryDict: {'user': ['liu'], 'pwd': ['222']}>
None

前端输出

用户名 密码  user or password error

整体流程就是这样,要注意json序列化和反序列化。

Ajax(简介、基础操作、计算器,登录验证)的更多相关文章

  1. AJAX - 实现一个简单的登录验证

    /**Ajax 编写流程 * 1.创建 XHR (XMLHttpRequest)对象 var xmlHttpReq = false; // var xmlHttpReq = ""; ...

  2. (2.2)学习笔记之mysql基础操作(登录及账户权限设置)

    本系列学习笔记主要讲如下几个方面: 本文笔记[三:mysql登录][四:账户权限设置][五:mysql数据库安全配置] 三.mysql登录 常用登录方式如下: 四.账户权限设置 (4.1)查看用户表, ...

  3. 关于AJAX的基础操作

    AJAX开发 AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术. AJAX = 异步 Java ...

  4. 基于Ajax与用户认证系统的登录验证

    一.登录页面 from django.contrib import admin from django.urls import path from blog import views urlpatte ...

  5. {Django基础七之Ajax} 一 Ajax简介 二 Ajax使用 三 Ajax请求设置csrf_token 四 关于json 五 补充一个SweetAlert插件(了解)

    Django基础七之Ajax 本节目录 一 Ajax简介 二 Ajax使用 三 Ajax请求设置csrf_token 四 关于json 五 补充一个SweetAlert插件(了解) 一 Ajax简介 ...

  6. {Django基础七之Ajax} 一 Ajax简介 二 Ajax使用 三 Ajax请求设置csrf_token 四 关于json 五 补充一个SweetAlert插件(了解)

    {Django基础七之Ajax} 一 Ajax简介 二 Ajax使用 三 Ajax请求设置csrf_token 四 关于json 五 补充一个SweetAlert插件(了解)   Django基础七之 ...

  7. 练习:python 操作Mysql 实现登录验证 用户权限管理

    python 操作Mysql 实现登录验证 用户权限管理

  8. jQuery之标签操作和返回顶部、登录验证、全选反选、克隆示例

    一.样式操作 1.JQ中的样式类 somenode.addClass();// 添加指定的CSS类名. somenode.removeClass();// 移除指定的CSS类名. somenode.h ...

  9. 2-功能1:基于用户认证组件和Ajax实现登录验证(图片验证码)

    1.登录页面的设计 (1)label标签的id属性 label标签的id属性,点击label标记,相当于点击了input框 bootstarp样式 class="form-group&quo ...

随机推荐

  1. devops持续集成

    目录 Devops 版本控制系统 Git安装 Git使用 git四种状态 git基础命令 git分支 git合并冲突 git标签 git命令总结 Github使用 创建仓库 HTTP协议 SSH协议 ...

  2. Interface注意事项

    Interface 成员声明 声明属性,默认static & final 声明方法,默认public interface Instrument { int VALUE = 5; // stat ...

  3. Logstash学习之路(四)使用Logstash将mysql数据导入elasticsearch(单表同步、多表同步、全量同步、增量同步)

    一.使用Logstash将mysql数据导入elasticsearch 1.在mysql中准备数据: mysql> show tables; +----------------+ | Table ...

  4. phoenix启动报错:org.apache.phoenix.exception.PhoenixIOException: SYSTEM.CATALOG

    错误: org.apache.phoenix.exception.PhoenixIOException: SYSTEM.CATALOG at org.apache.phoenix.util.Serve ...

  5. PHP jquer网页打印插件 PrintArea

    <!DOCTYPE html> <head> <meta charset="utf-8"> <meta http-equiv=" ...

  6. Redis核心原理-简单动态字符串SDS

    SDS简介 Redis是C语言编写的,但没有使用c语言的字符串结构,而是自己实现了一套简单动态字符串 simple dynamic string 简称SDS,SDS兼容C语言的字符串类型,原理类似Ja ...

  7. 你一定需要知道的高阶JAVA枚举特性!

    JAVA枚举,比你想象中还要有用! 我经常发现自己在Java中使用枚举来表示某个对象的一组潜在值. 在编译时确定类型可以具有什么值的能力是一种强大的能力,它为代码提供了结构和意义. 当我第一次了解枚举 ...

  8. 【C++】《Effective C++》第二章

    第二章 构造/析构/赋值运算 条款05:了解C++默默编写并调用哪些函数 默认函数 一般情况下,编译器会为类默认合成以下函数:default构造函数.copy构造函数.non-virtual析构函数. ...

  9. 改进你的c#代码的5个技巧(四)

    像每一篇文章一样,我会重复几行.我在我的Core i3 CPU.4GB主内存和Windows 7平台上测试了以下代码.如果你在不同的硬件配置或使用不同的平台,那么你的输出可能会随着我的输出屏幕而变化, ...

  10. CTF实验吧-WEB题目解题笔记(1)简单的登陆题

    1.简单的登陆题 解题链接: http://ctf5.shiyanbar.com/web/jiandan/index.php  Burp抓包解密 乱码,更换思路.尝试id intruder 似乎也没什 ...