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. Mapreduce实例--求平均值

    求平均数是MapReduce比较常见的算法,求平均数的算法也比较简单,一种思路是Map端读取数据,在数据输入到Reduce之前先经过shuffle,将map函数输出的key值相同的所有的value值形 ...

  2. git基础-git别名

    Git 并不会在你输入部分命令时自动推断出你想要的命令. 如果不想每次都输入完整的 Git 命令,可以通过 git config 文件来轻松地为每一个命令设置一个别名. 这里有一些例子你可以试试: $ ...

  3. 洛谷P4848 崂山白花蛇草水 权值线段树+KDtree

    题目描述 神犇 \(Aleph\) 在 \(SDOI\ Round2\) 前立了一个 \(flag\):如果进了省队,就现场直播喝崂山白花蛇草水.凭借着神犇 \(Aleph\) 的实力,他轻松地进了山 ...

  4. [ABP教程]第四章 集成测试

    Web应用程序开发教程 - 第三章: 集成测试 //[doc-params] { "UI": ["MVC","NG"], "DB& ...

  5. 使用 Flux,Helm v3,Linkerd 和 Flagger 渐进式交付 Kubernetes

    介绍 本指南将引导您在 Kubernetes 集群上设置渐进式交付 GitOps 管道. GitOps Helm 研讨会 原文地址:GitOps Progressive Deliver with Fl ...

  6. Github美化 添加徽章

    Github美化 添加徽章 0. 前言 1. 准备 2. 开始 a. 打开shields.io b.制作静态徽章 c.制作动态徽章 d. 结果 3.额外 0. 前言 之前看见很多大项目都有很多勋章,比 ...

  7. LeetCode108 将有序数组转为二叉搜索树

    将一个按照升序排列的有序数组,转换为一棵高度平衡二叉搜索树. 本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1. 示例: 给定有序数组: [-10,-3,0, ...

  8. 执行py文件需要可执行权限吗?

    案例解析 这个问题描述起来有点违反直觉,要执行一个文件难道不应该需要可执行权限吗?让我们先来看一个例子: # module1.py def test(): print ('hello world!') ...

  9. 一文带你学会AQS和并发工具类的关系2

    1.创建公平锁 1.使用方式 Lock reentrantLock = new ReentrantLock(true); reentrantLock.lock(); //加锁 try{ // todo ...

  10. 通过SE14重建数据库表

    通过程序中的SQL语句向数据库表中插入的内容,系统无法转换,并且已经存在于数据库表中,那么当对该表进行保存数据的修改时,可能会导致该表从数据库中的删除. 举了例子:(完全是为了方便理解) SAP系统, ...