Javaweb-ajax的使用

⭐⭐为什么要使用ajax?(why)

首先我们先说一下ajax与传统的from表单提交的区别:

ajax是什么?

AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。

AJAX 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下。

ajax的适用场景:

大部分地图app、弹幕、社交软件需要实时更新的评论等等,这些都是需要用到不跳转页面的无刷新,无刷新就是不刷新整个页面,值刷新局部。

无刷新的好处:

  • 只更新部分页面
  • 提高用户体验
  • 有效利用带宽

Ajax与Form表单的区别:

  1. Ajax在提交、请求、接收时,都是异步进行的,网页不需要刷新;Form提交则是新建一个页面,哪怕是提交给自己本身的页面,也是需要刷新的;
  2. Ajax在提交时,是在后台新建一个请求;Form却是放弃本页面,而后再请求;
  3. Ajax必须要使用JS来实现,不启用JS的浏览器,无法完成该操作;Form却是浏览器的本能,无论是否开启JS,都可以提交表单;
  4. Ajax在提交、请求、接收时,整个过程都需要使用程序来对其数据进行处理;Form提交时,却是根据你的表单结构自动完成,不需要代码干预。
     

ajax的工作原理:

ajax功能依赖浏览器的内置对象XHR(XmlHttpRequest)发送异步请求,当然,异步请求是不会妨碍客户端的任何操作的。

XHR相当于是一个通信兵,来负责客户端与服务器之间的通信传输。举个例子:

异步:

要打仗了,前方阵地(客服端)不可能只等着通信兵(XHR)传递消息其他什么也不干吧,所以前方阵地还在干着自己的事情然后派通信兵去请求后方指挥部(服务器)的命令,指挥部下达命令指挥,通信兵再把命令传到前方阵地,然后前方阵地再执行命令相关的操作(客户端把数据渲染到页面),这也就是Ajax的异步原理。

同步:

所谓的同步就是前方阵地和通信兵一起去向服务器请求数据,直到通信兵请求到数据,我才开始渲染页面,在请求的过程中页面一直是白屏等待的。

⭐⭐ajax的基本使用:

通过HTTP协议请求加载远程数据的几种形式:

(这里我使用的是jQuery,当然也能使用js,个人觉得jQuery用起来方便。)

1.post:jQuery.post(url, [data], [callback], [type])

常用参数

说    明

url

一个用来包含发送请求的URL字符串(请求地址)

data

发送到服务器的数据(参数)  key/value

success(data)

请求成功的回调函数

type

返回内容格式(xml、json、text等)

2.get::jQuery.get(url, [data], [callback], [type])

常用参数

说    明

url

一个用来包含发送请求的URL字符串(请求地址)

data

发送到服务器的数据(参数)  key/value

success(data)

请求成功的回调函数

type

返回内容格式(xml、json、text等)

3.$.ajax()

相比较前面两个get和post,ajax就显得复杂些。

常用参数

说    明

url

一个用来包含发送请求的URL字符串(请求地址)

type

请求方式 (“POST” 或 “GET“[默认])

data

发送到服务器的数据(参数)

dataType

预期服务器返回的数据类型(xml、json、text)

success(data)

请求成功的回调函数

error

请求失败的回调函数

三种形式的代码:

        $.get("url",data,fun(){},"text")
        $.post("url",data,fun(){},"text")
        $.ajax({
            url:"",
            type:"get|post",
            data:{},
            dataType:"",
            success(){}
        })

 datatype属性的几种基本类型:

xml,script,text.json,html

success请求成功指的是后端成功传值过来后就调用的函数。那么没传值过来就是调用error

⭐⭐案例:

⭐登录注册失败后值返回案例:

login.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java"%>
<html>
<head>
<title>Title</title>
<script src="js/jquery-3.3.1.js"></script>
</head>
<body>
	<div>
		<p>
			<input id="account" name="account">
		</p>
		<p>
			<input id="password" name="password">
		</p>
		<button onclick="login()">登录</button>
	</div>
	<script>
    function login() {
        //获取页面的值
        let account = $("#account").val()
        let password = $("#password").val()
        //通过jquery来发送请求ajax去后台 login.do

        //ajax方法:get|post
        $.ajax({
            url:"login.do",//访问地址
            data:{account,password},//携带的数据
            dataType:"text",//希望后台给你什么样子的数据
            type: "get",//什么请求类型
            success(resp){
                if (resp.trim() === "yes") {//这个地方需要使用到trim()函数去除空格,不然会传送失败
                    alert("登陆成功")
                    location.href = "index.jsp"
                } else {
                    alert("登陆失败")
                }
            },//成功
            error(){
				alert("数据传送失败!")
            }//错误
        })

        //当然也能够写成post和get
        /**
        $.get(
            //请求地址
            "login.do",
            //携带过去的数据 直接放数据,名字就是数据的名字
            {account, password},
            //回调函数 请求之后会调用这个函数
            //resp就是后台给我的值
            function (resp) {
                //trim 去空格
                //contains 包含
                if (resp.trim() === "yes") {
                    alert("登陆成功")
                    location.href = "index.jsp"
                } else {
                    alert("登陆失败")
                }
            },
            "text" //希望后台给我的是普通的文本
        )
         **/

        
    }
</script>
</body>
</html>

loginservlet.java

package com.ljq.servlet;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * 登录验证
 * 
 * @author 一麟
 *
 */
@SuppressWarnings("all")
@WebServlet("/login.do")
public class LoginServlet extends HttpServlet {

	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		doPost(req, resp);
	}

	@Override
	protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		// 去前端通过标签name属性拿值
		String account = req.getParameter("account");
		String password = req.getParameter("password");
		// 将数据传送至前端
		PrintWriter out = resp.getWriter();
		if ("root".equals(account) && "root123".equals(password)) {// 密码与账号都是定死的
			out.println("yes");
		} else {
			out.println("no");
		}
	}

}

效果图:

 

⭐注册时判断用户是否已经存在了: 

register.jsp

执行原理:去数据查询所有用户的名字,然后进行遍历比较,如果名字一致就在输入框的右边显示已经存在该用户。

<%@ page contentType="text/html;charset=UTF-8" language="java"%>
<html>
<head>
<title>Title</title>
<script src="js/jquery-3.3.1.js"></script>
<style>
#tip {
	color: red;
}
</style>
</head>
<body>
	<p>
		<input id="name" onkeyup="yz()" type="text" placeholder="请输入你的用户名"><span
			id="tip"></span>
	</p>
	<button id="register">去注册</button>
	<script>
    function yz(){
        //获取数据
        let name=$("#name").val()
        //发送请求
        $.get("find.do",{name},(resp)=>{
            if(resp.trim()==="true"){
                $("#tip").text("已经存在该用户")
                $("#register").prop("disabled",true)
            }else{
                $("#tip").text("")
                $("#register").prop("disabled",false)
            }
        },"text")
    }
</script>
</body>
</html>

findservlet.java

package com.ljq.servlet;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.List;

/**
 * 判断用户是否已经存在
 * 
 * @author 一麟
 *
 */
@SuppressWarnings("all")
@WebServlet("/find.do")
public class FindServlet extends HttpServlet {

	List<String> list = new ArrayList<String>();

	{
		list.add("黎明");
		list.add("夜晚");
		list.add("星辰");
		list.add("海平线");
		list.add("日落");
	}

	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		doPost(req, resp);
	}

	@Override
	protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		// 一般这个地方是需要进行数据库的查询,但是这里我就直接跳过了。
		String name = req.getParameter("name");
		boolean f = false;
		for (String n : list) {
			if (n.equals(name)) {
				f = true;
				break;
			}
		}
		// 将数据传送到前端去
		PrintWriter out = resp.getWriter();
		out.println(f);
	}

}

⭐使用搜索框时弹出的提示:

 index.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java"%>
<html>
<head>
<title>Title</title>
<script src="js/jquery-3.3.1.js"></script>
</head>
<body>
	<div>
		🔍 <input id="keyWord" name="keyWord" onkeyup="search()">
		<ul id="list">

		</ul>
	</div>
	<script>
    function search(){
        //得到输入框的值
        let keyWord=$("#keyWord").val()
        //发送到负责检索商品名称的servlet
        $.get("search.do",{keyWord},(resp)=>{
            //清空原来的选项
            $("#list").empty()
            //resp现在是从字符串变成了数组
            for(let n of resp){//foreach
                $("#list").append("<li>"+n+"</li>")
            }
        },"json");
    }

    //json
    //对象的字符串格式,json有固定的格式

    //将对象变成json
    //将json还原为对象
</script>
	
</body>
</html>

searchservlet.java

package com.ljq.servlet;

import com.fasterxml.jackson.databind.ObjectMapper;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.List;

/**
 * 
 * @author 一麟
 *
 */
@SuppressWarnings("all")
@WebServlet("/search.do")
public class SearchServlet extends HttpServlet {

	// 这个地方应该是去数据库拿值,但是为了方便,就直接省去这一步操作了
	List<String> list = new ArrayList<String>();

	{
		list.add("冰糖葫芦");
		list.add("草莓溜溜");
		list.add("酸甜榴莲");
		list.add("青丝苹果");
		list.add("无籽西瓜");
	}

	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		doPost(req, resp);
	}

	@Override
	protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		// 获取搜索框的值
		String keyWord = req.getParameter("keyWord");
		List<String> ns = new ArrayList<>();
		for (String n : list) {
			if (n.contains(keyWord)) {
				ns.add(n);
			}
		}
		// 设置编码放置乱码
		resp.setCharacterEncoding("utf-8");
		PrintWriter out = resp.getWriter();
		// 序列化Java对象到json
		ObjectMapper mapper = new ObjectMapper();// ObjectMapper(对象映射器)
		// 将对象系列化为json
		String str = mapper.writeValueAsString(ns);
		// 传送到前端
		out.println(str);
	}

}

objectMapper对象映射器 

json转换

1.将集合变成字符串  String str=JSON.toJSONString(ls); //ls为集合
2.将字符串变成集合
    使用js的eval()方法
    使用jQuery的$.parseJSON()

⭐二级联动

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一麟yl

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值