彻底舍弃服务器端渲染,数据全部通过Ajax方式以JSON格式来传递。
Ajax本身就是Asynchronous JavaScript And XML的缩写,直译为:异步的JavaScript和XML。在实际应用中Ajax指的是:不刷新浏览器窗口,不做页面跳转,局部更新页面内容的技术。
**『同步』和『异步』**是一对相对的概念,那么什么是同步,什么是异步呢?
多个操作按顺序执行,前面的操作没有完成,后面的操作就必须等待。所以同步操作通常是串行的。
多个操作相继开始并发执行,即使开始的先后顺序不同,但是由于它们各自是在自己独立的进程或线程中完成,所以互不干扰,谁也不用等谁。
在不采用其他工具的情况下
JSON 全称“JavaScript Object Notation”,译为“JavaScript 对象简谱”或“JavaScript 对象表示法”,是一种轻量级的、基于文本的、开放的数据交换格式
JSON 在 Web 开发领域有着举足轻重的地位,如果您想在 Web 开发领域大展身手的话,就必须了解 JSON。
JSON 是一种纯字符串形式的数据,它本身不提供任何方法(函数),非常适合在网络中进行传输。JavaScript、PHP、Java、Python、C++ 等编程语言中都内置了处理 JSON 数据的方法。
通过上述文字的描述,我们可以知道,JSON就是网络传输数据时的一种规范,能让客户端和服务器端都能识别传输过来的数据,并以这种规范来编写数据传输给对方
//JSON是一种数据格式
// XML也是一种数据格式
// XML格式表示两个学员信息的代码如下:
jim 18 tom 19
//JSON格式表示两个学员信息的代码如下:
[{sid:"s001",age:18},{sid:"s002",age:19}]
表示一个数字
2.90
表示一个字符串
"Hello World"
{"name":"smith","age":30,"sex":男
}
以上就是用JSON表示一个对象,对象的属性也使用双引号括起来,这是一种标准写法
JSON中的属性还可以是对象
对象的属性也可以是JSON对象
{"name":"smith","age":18"sex":男"school":{"sname":"南京大学","address":"南京市鼓楼区汉口路22号"}
}
保存名字的数字:["尼古拉斯","斯巴达","雅典娜"]
保存雇员的信息:["尼古拉斯",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]
]
JSON序列化
JSON反序列化
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'}
使用原生的JavaScript程序执行Ajax极其繁琐,所以一定要使用框架来完成。而Axios就是目前最流行的前端Ajax框架。
使用原生JavaScript来执行Ajax
HTML标签
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.(完成)响应内容解析完成,可以在客户端调用了
1演示Axois发送普通的参数值给服务端
uname:
pwd:
后端代码
@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
前端页面
演示Axios发送异步请求给服务器端,服务器响应json格式的数据给客户端
uname:
pwd:
后端代码
@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);}
}