第十九章AJAX学习

news2025/1/10 10:36:56

文章目录

  • 什么是AJAX
    • 服务器端渲染
    • Ajax渲染(局部更新)
    • 前后端分离
    • 同步与异步
      • 同步
      • 异步
      • 前端提交到数据到后端的方式
  • JSON
    • 什么是JSON
    • JSON数据格式
      • JSON对象
      • JSON格式表示简单数组
      • 对象数组
      • 使用二维数组保存
    • 对于客户端
    • 对于服务器端
      • 引入GSON的jar包
      • 使用例子
  • Axios简介
    • Axios基本用法
      • 引入对应的js文件
      • 利用Axios发送普通类型请求参数
      • 发送JSON类型数据

什么是AJAX

服务器端渲染

./images

  • 对应我们的服务器端渲染,对应的是一个完整的页面,

Ajax渲染(局部更新)

./images

  • 对应我们的ajax,响应的是一个数据片段,我们用数据片段去修改我们的页面
  • 目的: 用来发送异步的请求,然后当服务器给我响应的时候再进行回调操作

前后端分离

彻底舍弃服务器端渲染,数据全部通过Ajax方式以JSON格式来传递。

  • 也就是放弃了thymeleaf渲染

同步与异步

Ajax本身就是Asynchronous JavaScript And XML的缩写,直译为:异步的JavaScript和XML。在实际应用中Ajax指的是:不刷新浏览器窗口不做页面跳转局部更新页面内容的技术。

**『同步』『异步』**是一对相对的概念,那么什么是同步,什么是异步呢?

同步

多个操作按顺序执行,前面的操作没有完成,后面的操作就必须等待。所以同步操作通常是串行的。

./images

异步

多个操作相继开始并发执行,即使开始的先后顺序不同,但是由于它们各自是在自己独立的进程或线程中完成,所以互不干扰谁也不用等谁

image-20230105163628589

  • 好处: 提高用户体验;局部刷新:降低服务器负担、减轻浏览器压力、减轻网络带宽压力

前端提交到数据到后端的方式

在不采用其他工具的情况下

  • 采用from表单形式。form表单的后序处理,建议重定向,这样浏览器会自动重定向到指定的资源上
  • 采用ajax+请求体:JSON的形式,ajax的后序处理,建议还是返回JSON,方便JS后序的处理,JS读取用户的输入,发起请求提交内容,根据结果继续修改页面或者重新载入页面
    • 了解什么是JSON

JSON

什么是JSON

  • JSON 全称“JavaScript Object Notation”,译为“JavaScript 对象简谱”或“JavaScript 对象表示法”,是一种轻量级的、基于文本的、开放的数据交换格式

    JSON 在 Web 开发领域有着举足轻重的地位,如果您想在 Web 开发领域大展身手的话,就必须了解 JSON。

  • JSON 是一种纯字符串形式的数据,它本身不提供任何方法(函数),非常适合在网络中进行传输。JavaScript、PHP、Java、Python、C++ 等编程语言中都内置了处理 JSON 数据的方法。

    • JSON 是基于 JavaScript的一个子集,是一种开放的、轻量级的数据交换格式,采用独立于编程语言的文本格式来存储和表示数据,易于程序员阅读与编写,同时也易于计算机解析和生成,通常用于在 Web 客户端(浏览器)与 Web 服务器端之间传递数据。

通过上述文字的描述,我们可以知道,JSON就是网络传输数据时的一种规范,能让客户端和服务器端都能识别传输过来的数据,并以这种规范来编写数据传输给对方

//JSON是一种数据格式
// XML也是一种数据格式
// XML格式表示两个学员信息的代码如下:
<students>
	<student sid="s001">
		<sname>jim</sname>
            <age>18</age>
        </student>
        <student sid="s002">
            <sname>tom</sname>
            <age>19</age>
        </student>
      </students>
//JSON格式表示两个学员信息的代码如下:
[{sid:"s001",age:18},{sid:"s002",age:19}]

JSON数据格式

表示一个数字

2.90

表示一个字符串

"Hello World"

JSON对象

{
	"name":"smith",
	"age":30,
	"sex":}

以上就是用JSON表示一个对象,对象的属性也使用双引号括起来,这是一种标准写法

  • JS中的对象格式:大括号{name1:value,name2:value}
  • name必须是字符串类型,value在JS代码下,可以是任意的类型,数组,函数,另一个对象等
  • name必须是双引号包裹,JS可以省略引号,也可以用单引号
  • value类型不能是函数类型,数据可以有null,但不会有undefined

JSON中的属性还可以是对象

对象的属性也可以是JSON对象

{
	"name":"smith",
	"age":18
	"sex":"school":{
		"sname":"南京大学",
		"address":"南京市鼓楼区汉口路22号"
	}
}

JSON格式表示简单数组

保存名字的数字:["尼古拉斯","斯巴达","雅典娜"]
保存雇员的信息:["尼古拉斯",1001,"总裁",7788,50000.0010000.0]

对象数组

在一个数字中保存多个JSON对象

[
	{
		"title":"Java实战经典开发",
		"edition":3,
		"author":["smith","尼古拉斯","斯巴达"]
	},
	{
		"title":"Oracle实战经典开发",
		"edition":3,
		"author":["smith","尼古拉斯","斯巴达"]
	},
	{
		"title":"Vue实战经典开发",
		"edition":5,
		"author":["smith","尼古拉斯","斯巴达"]
	}
]

使用二维数组保存

[
	["smith",1001,"clerck",7788,2000.00]
	["smith",1001,"clerck",7788,2000.00]
	["smith",1001,"clerck",7788,2000.00]
]

对于客户端

  • 我们的客户端也就是我们的浏览器,对应写的代码是JavaScript,我们的JavaScript来说是有内置的JSON转换API

image-20230105174248672

JSON序列化

img

JSON反序列化

image-20230105174749942

对于服务器端

  • 我们服务器端写的代码是Java代码,我们的JDK是没有对应的JSON序列化的API,需要引入第三方的jar包
    • jackson SSM默认情况下使用的是这个
    • GSON
    • fastjson 阿里巴巴开源的,但是BUG太多了

引入GSON的jar包

image-20230105180715871

使用例子

User类

package com.lsc.pojo;

public class User {
    private String uname ;
    private String pwd ;

    public User(){}

    public User(String uname, String pwd) {
        this.uname = uname;
        this.pwd = pwd;
    }


    @Override
    public String toString() {
        return "User{" +
                "uname='" + uname + '\'' +
                ", pwd='" + pwd + '\'' +
                '}';
    }
}

public class Json1 {
    public static void main(String[] args) {
        User user=new User("刘颂成","123456");
        Gson gson=new Gson();
        //1.fromJson(string,T) 将字符串转化成java object
        //2.toJson(java Object) 将java object转化成json字符串,这样才能响应给客户端
        String userJsonStr = gson.toJson(user);//将一个对象转换为JSON String
        System.out.println(userJsonStr);
        User userByJson=gson.fromJson(userJsonStr,User.class);//将一个JSON String转换为User对象
        System.out.println(userByJson);
    }
}
{"uname":"刘颂成","pwd":"123456"}
User{uname='刘颂成', pwd='123456'}

Axios简介

使用原生的JavaScript程序执行Ajax极其繁琐,所以一定要使用框架来完成。而Axios就是目前最流行的前端Ajax框架。

  • 我们利用vue和axios来简化开发

使用原生JavaScript来执行Ajax

HTML标签

 <input id="unameTxt" type="text" placeholder="请输入用户名" name="uname" value="刘颂成" οnblur="ckUname(this.value)" />
  • 当用户离开输入字段时执行 ckUname方法(JS方法)

JS代码

//如果想要发送异步请求,我们需要一个关键的对象 XMLHttpRequest
var xmlHttpRequest ;
function createXMLHttpRequest() {
    if(window.XMLHttpRequest){
        //符合DOM2标准的浏览器 ,xmlHttpRequest的创建方式
        xmlHttpRequest = new XMLHttpRequest() ;
    }else if(window.ActiveXObject){//IE浏览器
        try{
            xmlHttpRequest = new ActiveXObject("Microsoft.XMLHTTP");
        }catch (e) {
            xmlHttpRequest = new ActiveXObject("Msxml2.XMLHTTP")
        }
    }
}//因为不同的浏览器有不同的标准

function ckUname(uname){
    createXMLHttpRequest();//创建 XMLHttpRequest对象
    var url="user.do?operate=ckUname&uname="+uname;//设置请求
    xmlHttpRequest.open("GET",url,true);
    //设置回调函数 当请求得到服务器的响应时候的执行的JS方法
    xmlHttpRequest.onreadystatechange = ckUnameCB ;
    //发送请求
    xmlHttpRequest.send();
}
function ckUnameCB(){
    if(xmlHttpRequest.readyState==4&&xmlHttpRequest.status==200){
        //xmlHttpRequest.responseText 表示 服务器端响应给我的文本内容
        //alert(xmlHttpRequest.responseText);
        var responseText = xmlHttpRequest.responseText ;
        // {'uname':'1'}
        //alert(responseText);
        if(responseText=="{'uname':'1'}"){
            alert("用户名已经被注册!");
        }else{
            alert("用户名可以注册!");
        }
    }
}

开发步骤:

  • 创建XMLHttpRequest

  • 调用open进行设置:“GET” , URL , true

  • 绑定状态改变时执行的回调函数 - onreadystatechange

  • 发送请求 - send()

  • 编写回调函数,在回调函数中,我们只对XMLHttpRequest的readystate为4的时候感兴趣,我们只对XMLHttpRequest的status为200的时候感兴趣

    • 0: (Uninitialized) the send( ) method has not yet been invoked.(未初始化)还没有调用send()方法

    • 1: (Loading) the send( ) method has been invoked, request in progress.(载入)已调用send()方法,正在发送请求

    • 2: (Loaded) the send( ) method has completed, entire response received.(载入完成)send()方法执行完成,已经接收到全部响应内容

    • 3: (Interactive) the response is being parsed.(交互)正在解析响应内容

    • 4: (Completed) the response has been parsed, is ready for harvesting.(完成)响应内容解析完成,可以在客户端调用了

Axios基本用法

引入对应的js文件

image-20230105183305035

利用Axios发送普通类型请求参数

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>1演示Axois发送普通的参数值给服务端</title>
    <script language="JavaScript" src="script/vue.js"></script>
    <script language="JavaScript" src="script/axios.min.js"></script>
    <script language="JavaScript">
        window.onload=function (){
            var vue=new Vue({
                "el":"#div0",
                data:{
                    uname:"lsc",
                    pwd:"ok"
                },
                methods:{
                    axios1:function (){
                        axios({
                            method:"POST",
                            url:"axios1.do",
                            params:{
                                uname: vue.uname,
                                pwd:vue.pwd
                            }
                        })
                            .then(function (value) {
                                console.log(value);
                            })
                            .catch(function (reason) {
                                console.log(reason);
                            });
                    }
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    uname:<input type="text" v-model="uname" /><br/>
    pwd:<input type="text" v-model="pwd" /><br/>
    <input type="button" @click="axios1" value="发送一个带普通请求参数值的异步请求" />
</div>
</body>
</html>



image-20230105194137229

  • 观察我们的value的结构

后端代码

@WebServlet("/axios1.do")
public class Axios01Servlet extends HttpServlet {
    @Override
    protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        request.setCharacterEncoding("utf-8");

        String uname = request.getParameter("uname");
        String pwd = request.getParameter("pwd");

        System.out.println("uname = " + uname);
        System.out.println("pwd = " + pwd);

        response.setCharacterEncoding("utf-8");
        response.setContentType("text/html;charset=utf-8");
        PrintWriter out = response.getWriter();
        out.write(uname+"_"+pwd);
    }
}
//uname = lsc
//pwd = ok

发送JSON类型数据

前端页面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>演示Axios发送异步请求给服务器端,服务器响应json格式的数据给客户端</title>
    <script language="JavaScript" src="script/vue.js"></script>
    <script language="JavaScript" src="script/axios.min.js"></script>
    <script language="JavaScript">
        window.onload=function (){
            var vue=new Vue({
                "el":"#div0",
                data:{
                    uname:"lina",
                    pwd:"ok"
                },
                methods:{
                    axios:function (){
                        axios({
                            method:"POST",
                            url:"axios2.do",
                            data: {
                                uname: vue.uname,
                                pwd:vue.pwd
                            }
                        })
                            .then(function (value) {
                                var data = value.data;//
                                // data对应的数据:
                                // {uname:"小阿成",pwd:"lsc1223"}
                                vue.uname=data.uname;
                                vue.pwd=data.pwd;
                                //此处value中的data返回的是 js object,因此可以直接点出属性
                            
                                //如果我们获取的是一个字符串:  "{uname:\"鸠摩智\",pwd:\"ok\"}"
                                //js语言中 也有字符串和js对象之间互转的API
                                //string JSON.stringify(object)     object->string
                                //object JSON.parse(string)         string->object
                            })
                            .catch(function (reason) {
                                console.log(reason);
                            });
                    }
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    uname:<input type="text" v-model="uname"/><br/>
    pwd:<input type="text" v-model="pwd"/><br/>
    <input type="button" @click="axios" value="服务器响应json格式的数据给客户端"/>
</div>
</body>
</html>

image-20230105193435616

  • 我们可以知道返回的data是一个Object(我们的axios将json字符串变成了一个JS对象),所以可以通过.来获取对应的数据

后端代码

@WebServlet("/axios2.do")
public class Axios02Servlet extends HttpServlet {
    @Override
    protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        StringBuffer stringBuffer=new StringBuffer();
        BufferedReader bufferedReader=request.getReader();
        String str=null;
        while((str=bufferedReader.readLine())!=null){
            stringBuffer.append(str);
        }
        str = stringBuffer.toString() ;
        //已知 String
        //需要转化成 Java Object
        Gson gson=new Gson();
        //Gson有两个API
        //Gson有两个API
        //1.fromJson(string,T) 将字符串转化成java object
        //2.toJson(java Object) 将java object转化成json字符串,这样才能响应给客户端
        User user =gson.fromJson(str,User.class);
        user.setUname("小阿成");
        user.setPwd("lsc1223");
        //假设user是从数据库中查询出来的,现在需要转换为JSON String
        String userJsonStr=gson.toJson(user);
        response.setCharacterEncoding("UTF-8");
        //MIME-TYPE
        response.setContentType("application/json;charset=utf-8");
        response.getWriter().write(userJsonStr);
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/146455.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL数据库:库和表的基本操作

SQL注意事项 1.每条sql语句都要以英文分号结尾。 2.sql语句不区分大小写。 3.定义库、表&#xff0c;或是表中的字段&#xff0c;名称不要使用关键字。 一、数据库的操作 1.显示所有的数据库 show databases; 2.创建数据库 方式一&#xff1a; create database 数据库名称…

vue+elementui导入Excel文件(基于vue-element-admin中的uploadExcel组件), 然后 go-zero进行逻辑处理功能

#前端代码 html代码 <el-button v-waves class"filter-item" type"primary" icon"add" click"downLoadExlce">模板下载</el-button> <el-upload class"upload" action :multiple"false" :show-…

2.两数相加(链表)

题目 给你两个 非空 的链表&#xff0c;表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的&#xff0c;并且每个节点只能存储 一位 数字。 请你将两个数相加&#xff0c;并以相同形式返回一个表示和的链表。 你可以假设除了数字 0 之外&#xff0c;这两个数都不会…

【Linux】动静态库的制作和使用

目录 一、可执行文件的形成 二、静态库 2.1 制作静态库 2.2 使用静态库 三、动态库 3.1 动态库的制作 3.2 动态库链接 2.3 动态库的加载 一、可执行文件的形成 在C语言中&#xff0c;函数库文件分为两种类型&#xff1a; 静态库&#xff08;库程序是直接注入目标程序…

想要做成一件事,就得有方法,怎么做到呢

想要完成一件事&#xff0c;没有详细的计划和方法是做不好的。如果没有计划&#xff0c;没有方案&#xff0c;没有策略&#xff0c;没有规划&#xff0c;没有方法&#xff0c;那就是一只无头苍蝇&#xff0c;到处乱撞&#xff0c;不能达到什么目的。想做成一件事&#xff0c;就…

后端人眼中的Vue(二)

三、Vue基本语法 3.1、展示数据 3.1.1、v-text 3.1.1.1、简介 ​ 和插值表达式&#xff08;{{}}&#xff09;一样&#xff0c;用于获取vue实例中data属性声明的数据。用法是在哪个标签上获取就直接在哪个标签上定义v-text或者是v-html。相当于javascript中的innerText。直接…

笔记:Android 系统架构

Android系统架构 1.应用层&#xff08;System Apps&#xff09; 系统内置应用程序和非系统应用程序&#xff0c;源码目录中的 packages 目录对应系统应用层 2.应用架构层&#xff08;Framework&#xff09; 为开发人员提供应用程序开发所需要的API&#xff0c;向下与c/c程序…

J-Tech Talk|跨模态视频检索进阶,一起探索CLIP模型的新天地!

J-Tech Talk由 Jina AI 社区为大家带来的技术分享围绕 Python 的相关话题工程师们将深入细节地讲解具体的问题分享 Jina AI 在开发过程中所积累的经验CLIP 模型在零样本图像分类、跨模态检索中效果拔群&#xff0c;它的出现同时推动了 NLP 和 CV 的发展&#xff0c;为解决许多实…

【自学C++】C++转义字符

C转义字符 C转义字符教程 在编程中有一些字符是打不出来的&#xff0c;比如换行&#xff0c;提示音&#xff0c;下一个制表位等等&#xff0c;于是程序语言的开发者就设计了转义序列&#xff08;escape sequence&#xff09;这种东西用来表达这些字符。 所谓转义&#xff0c…

jvm学习的核心(二)---运行时数据区概述

文章目录1.方法区&#xff08; Method Area&#xff09;2.堆&#xff08;Heap&#xff09;3.本地方法栈&#xff08;Native Method Stacks&#xff09;4.程序计数器&#xff08;pc Register&#xff09;5.虚拟机栈&#xff08;Virtual Machine Stacks&#xff09;运行时数据区 …

IDEA启动项目通过https进行访问,nginx配置https访问

一、IDEA启动项目通过https进行访问 1、获取证书 证书申请网络有很多方法&#xff0c;这里腾讯云的nginx版证书举列 2、证书转换 springboot是识别p12证书的&#xff0c;所有这里需要吧pem证书进行转换。转换工具OpenSSL-Win64&#xff08;自行百度下载&#xff09;下载完…

nodejs操作MySQL数据库

1、操作数据库的步骤 安装操作 MySQL 数据库的第三方模块&#xff08;mysql&#xff09;通过 mysql 模块连接到 MySQL 数据库通过 mysql 模块执行 SQL 语句2、安装与配置 mysql 模块 2.1、安装 mysql 模块 mysql 模块是托管于 npm 上的第三方模块。它提供了在 Node.js 项目中…

【Centos】服务管理、解/压缩、磁盘、进程管理相关命令

文章目录一、服务管理1 service2 chkconfig设置后台服务器的自启配置3 systemctl设置后台服务器自启配置防火墙关闭4 开关机重启5 搜索查找类6 locate快速定位文件路径二、压缩、解压1 gzip2 zip3 tar三、磁盘查看和分区类1 du2 df3 lsblk4 mount5 fdisk四、进程管理类1 iotop2…

Vue基础入门小demo——图片切换(初阶)

文章目录 &#x1f4cb;前言 &#x1f3af;demo介绍 &#x1f3af;完整代码 &#x1f3af;最终效果 &#x1f3af;案例解析 &#x1f4cb;前言 图片切换是一个很经典的Vue入门学习案例&#xff0c;在你学习完一些基本的v-指令后&#xff0c;你可以尝试去写一个简单的demo去…

吴恩达【神经网络和深度学习】Week3——浅层神经网络

文章目录Shallow Neural Network1、Neural Networks Overview2、Neural Network Representation3、Computing a Neural Networks Output4、Vectorizing Across Multiple Examples5、Explanation for Vectorized Implementation6、Activation Functions7、Why do you need Non-L…

年底固定资产盘点的正确招数

企业年终盘点的必要性 年终盘点的最终目的是摸清资产现状&#xff0c;掌握资产情况&#xff0c;为日常管理和来年采购预算做有力数据支撑&#xff0c;指导我们接下来应该怎么去做&#xff0c;对任何一家企业的管理都有着重要意义。 随着企业规模的扩大&#xff0c;员工和企业设…

SCI论文解读复现【NO.4】FINet:基于合成雾和改进YOLOv5的绝缘子数据集和检测基准(代码已复现)

此前出了目标检测算法改进专栏&#xff0c;但是对于应用于什么场景&#xff0c;需要什么改进方法对应与自己的应用场景有效果&#xff0c;并且多少改进点能发什么水平的文章&#xff0c;为解决大家的困惑&#xff0c;此系列文章旨在给大家解读发表高水平学术期刊中的SCI论文&am…

Redisson获取/释放分布式锁流程中使用的方法以及watchDog机制相关源码分析

Redisson获取/释放分布式锁原理以及watchDog机制相关源码分析使用到的重点类继承结构RedissonLockExpirationEntry获取锁的代码逻辑tryLock()tryLock(long waitTime, long leaseTime, TimeUnit unit)tryAcquire(long waitTime, long leaseTime, TimeUnit unit, long threadId)t…

变量作用域 和 多文件编程

变量作用域 目录&#xff1a;变量作用域概念typedef声明局部变量全局变量静态变量c存储类auto 自动存储类static 静态存储register 注册存储类extern 外部存储类多文件编程多文件编程概念步骤include <> 和 #include ""的区别防止头文件重复包含使用宏定义避免…

编写playbook ansible(5)

目录 题目&#xff1a; 1.按照要求定义以下变量。&#xff08;可以在多个位置下定义实现相应操作即可&#xff09; 2.编写任务模块在node1和node2主机中根据以上变量值创建对应文本文件以及用户名和安装软件包。 题目&#xff1a; 1.按照要求定义以下变量。&#xff08;可以…