第十九章AJAX学习
创始人
2024-05-08 21:11:58
0

文章目录

  • 什么是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格式表示两个学员信息的代码如下:
jim18tom19
//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.00,10000.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;}@Overridepublic 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 StringSystem.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标签

 
  • 当用户离开输入字段时执行 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发送普通类型请求参数



1演示Axois发送普通的参数值给服务端


uname:
pwd:

image-20230105194137229

  • 观察我们的value的结构

后端代码

@WebServlet("/axios1.do")
public class Axios01Servlet extends HttpServlet {@Overrideprotected 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类型数据

前端页面



演示Axios发送异步请求给服务器端,服务器响应json格式的数据给客户端


uname:
pwd:

image-20230105193435616

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

后端代码

@WebServlet("/axios2.do")
public class Axios02Servlet extends HttpServlet {@Overrideprotected 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 ObjectGson 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 StringString userJsonStr=gson.toJson(user);response.setCharacterEncoding("UTF-8");//MIME-TYPEresponse.setContentType("application/json;charset=utf-8");response.getWriter().write(userJsonStr);}
}

相关内容

热门资讯

美国不提安卓系统华为,迈向自主... 华为与美国:一场关于技术、市场与政策的较量在当今这个数字化的世界里,智能手机已经成为我们生活中不可或...
安卓系统怎么打开ppt,选择文... 你有没有遇到过这种情况:手里拿着安卓手机,突然需要打开一个PPT文件,却怎么也找不到方法?别急,今天...
谷歌退回到安卓系统,探索创新未... 你知道吗?最近科技圈可是炸开了锅,谷歌竟然宣布要退回到安卓系统!这可不是一个简单的决定,背后肯定有着...
安卓系统待机耗电多少,深度解析... 你有没有发现,手机电量总是不经用?尤其是安卓系统,有时候明明没怎么用,电量就“嗖”的一下子就下去了。...
小米主题安卓原生系统,安卓原生... 亲爱的手机控们,你是否曾为手机界面单调乏味而烦恼?想要给手机换换“衣服”,让它焕然一新?那就得聊聊小...
voyov1安卓系统,探索创新... 你有没有发现,最近你的手机是不是变得越来越流畅了?没错,我要说的就是那个让手机焕发青春的Vivo V...
电脑刷安卓tv系统,轻松打造智... 你有没有想过,家里的安卓电视突然变得卡顿,反应迟钝,是不是时候给它来个“大保健”了?没错,今天就要来...
安卓系统即将要收费,未来手机应... 你知道吗?最近有个大消息在科技圈里炸开了锅,那就是安卓系统可能要开始收费了!这可不是开玩笑的,这可是...
雷凌车载安卓系统,智能出行新体... 你有没有发现,现在的汽车越来越智能了?这不,我最近就体验了一把雷凌车载安卓系统的魅力。它就像一个聪明...
怎样拍照好看安卓系统,轻松拍出... 拍照好看,安卓系统也能轻松搞定!在这个看脸的时代,拍照已经成为每个人生活中不可或缺的一部分。无论是记...
安卓车机系统音频,安卓车机系统... 你有没有发现,现在越来越多的汽车都开始搭载智能车机系统了?这不,咱们就来聊聊安卓车机系统在音频方面的...
老苹果手机安卓系统,兼容与创新... 你手里那台老苹果手机,是不是已经陪你走过了不少风风雨雨?现在,它竟然还能装上安卓系统?这可不是天方夜...
安卓系统7.dns,优化网络连... 你有没有发现,你的安卓手机最近是不是有点儿“慢吞吞”的?别急,别急,让我来给你揭秘这可能与你的安卓系...
安卓手机系统怎么加速,安卓手机... 你有没有发现,你的安卓手机最近变得有点“慢吞吞”的?别急,别急,今天就来给你支几招,让你的安卓手机瞬...
小米note安卓7系统,探索性... 你有没有发现,手机更新换代的速度简直就像坐上了火箭呢?这不,小米Note这款手机,自从升级到了安卓7...
安卓和鸿蒙系统游戏,两大系统游... 你有没有发现,最近手机游戏界可是热闹非凡呢!安卓和鸿蒙系统两大巨头在游戏领域展开了一场激烈的较量。今...
安卓手机没有系统更,揭秘潜在风... 你有没有发现,现在安卓手机的品牌和型号真是五花八门,让人挑花了眼。不过,你知道吗?尽管市面上安卓手机...
充值宝带安卓系统,安卓系统下的... 你有没有发现,最近手机上的一款充值宝APP,在安卓系统上可是火得一塌糊涂呢!这不,今天就来给你好好扒...
安卓系统8.0镜像下载,轻松打... 你有没有想过,想要给你的安卓手机升级到最新的系统,却不知道从哪里下载那个神秘的安卓系统8.0镜像呢?...
安卓系统修改大全,全方位修改大... 你有没有想过,你的安卓手机其实是个大宝藏,里面藏着无数可以让你手机焕然一新的秘密?没错,今天就要来个...