Ajax技术

目录

一.Ajax简介

1.特点

2.发送请求的方式

3.简介

二.Ajax引入

1.案例

后端:

html前端:

2.小结

(1)基本语法

(2)注意

(3)HttpResponse解决方式


一.Ajax简介

1.特点

异步提交,局部刷新

动态获取用户名,实时跟后端确认并将结果展示给前端

2.发送请求的方式

  • 向后端发送请求的方式
    • 浏览器地址直接url回车
      • GET请求
    • a标签的href属性
      • GET请求
    • form表单
      • GET请求/POST请求
    • Ajax
      • GET请求/POST请求

3.简介

Ajax不是新的编程语言,而是一种使用现有标准的新方法(类比装饰器)

Ajax最大的优点就是不重新加载页面的情况下,可以与服务器交换数据并更新部分网页内容

这种特点给用户的感觉就是在不知不觉中完成了请求和响应过程

  • Ajax(Asynchronous JavaScript and XML)是一种用于创建动态网页的编程技术。

    • 它通过在网页上进行异步数据传输,实现了在不重新加载整个页面的情况下更新部分页面内容的能力。
  • Ajax的核心技术包括使用JavaScript和XMLHttpRequest对象与服务器进行数据交互,以及利用DOM(Document Object Model)来动态地更新页面。

  • 通过使用Ajax,网页可以在后台与服务器进行数据交换,并在不刷新整个页面的情况下,根据服务器返回的数据实时更新页面的某些部分。

  • 这种技术带来了很多好处,比如提高了用户体验、减少了网络流量和服务器负载,并使得开发人员能够创建更加交互和动态的网页应用程序。

  • 虽然Ajax最初是指Asynchronous JavaScript and XML,但如今已经不仅限于使用XML作为数据传输的格式,而是可以使用各种格式,如JSON(JavaScript Object Notation)。

  • 总结起来,Ajax是一种强大的前端开发技术,通过异步数据传输和动态页面更新,提供了更好的用户体验和交互性,广泛应用于现代Web应用程序的开发中。

二.Ajax引入

1.案例

  • 页面上有三个input框
    • 在前面两个框输入数字,点击按钮,朝后端发送Ajax请求
    • 在后端计算出结果,再返回给前端动态展示的第三个input框中
  • 要求
    • 整个过程页面不能刷新,也不许在前端计算

后端:

from django.http import JsonResponse
from django.shortcuts import render, HttpResponse
import json


# Create your views here.
def ab_ajax(request):
    if request.method == 'POST':
        # print(request.POST)  # 
        num1 = request.POST.get('i1')  # 3 - 文本类型
        num2 = request.POST.get('i2')  # 4 - 文本类型
        # 强转类型并做运算
        sum = int(num1) + int(num2)
        # 返回数据
        data = {
            "message": "success",
            "sum": sum,
        }
        # 需要将数据序列化进行传输
        return JsonResponse(data)
    return render(request, 'ab_ajax.html')

html前端:



+
=

2.小结

(1)基本语法


(2)注意

  • 针对后端如果是用HttpResponse返回的数据,回调函数不会自动帮助我们反序列化
  • 针对后端如果是用JsonResponse返回的数据,回调函数会自动帮助我们反序列化

(3)HttpResponse解决方式

  • 后端先进行序列化,再返回数据给前端
  • 前端加参数进行反序列化

你可能感兴趣的:(ajax,前端,javascript,django,python,后端,数据库)