【Java EE 学习 33 上】【JQuery样式操作】【JQuery中的Ajax操作】【JQuery中的XML操作】

时间:2022-03-15 00:45:45

一、JQuery中样式的操作

  1.给id=mover的div采用属性增加样式.one

$("#b1").click(function(){
$("#mover").attr("class","one");
});

  2.给span块使用addClass增加样式.one

$("#b2").click(function(){
$("span").addClass("one");
});

  3.给id=mover的div块使用removeClass移除.one样式

$("#b3").click(function(){
$("#mover").removeClass("one");
});

  4.id=mover的div块切换样式.one:切换样式是原有样式和添加新样式之间进行切换,并非是在添加两个新样式之后在两个新样式之间进行切换。

$("#b4").click(function(){
$("#mover").toggleClass("one");
});

  5.判断span元素是否有spanone样式

 $("#b5").click(function(){
var result=$("span").first().hasClass("spanone");
alert(result);
});

  6.完整代码

 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>ddd</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script language="JavaScript" src="../js/jquery-1.4.2.js"></script>
<style type="text/css">
.one{
width: 200px;
height: 140px;
margin: 40px;
background: red;
border: #000 1px solid;
float:left;
font-size: 17px;
font-family:Roman;
} div,span{
width: 140px;
height: 140px;
margin: 20px;
background: #9999CC;
border: #000 1px solid;
float:left;
font-size: 17px;
font-family:Roman;
} /* div.mini{
width: 30px;
height: 30px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
} */
</style>
<!--引入jquery的js库-->
</head>
<body>
<input type="button" value="给id=mover的div采用属性增加样式.one" id="b1"/>
<input type="button" value=" 给span块使用addClass增加样式.one" id="b2"/>
<input type="button" value="给id=mover的div块使用removeClass移除.one样式" id="b3"/>
<input type="button" value=" id=mover的div块切换样式.one" id="b4"/>
<input type="button" value=" hasClass:判断span元素是否有spanone元素" id="b5"/> <h1>天气冷了</h1>
<h2>天气又冷了</h2> <br>
<div id="mover">
动画
</div>
<br>
<span class="spanone"> span
</span> </body>
<script type="text/javascript">
//<input type="button" value="给id=mover的div采用属性增加样式.one" id="b1"/>
$("#b1").click(function(){
$("#mover").attr("class","one");
});
//<input type="button" value=" 给span块使用addClass增加样式.one" id="b2"/>
$("#b2").click(function(){
$("span").addClass("one");
}); //<input type="button" value="给id=mover的div块使用removeClass移除.one样式" id="b3"/>
$("#b3").click(function(){
$("#mover").removeClass("one");
}); //<input type="button" value=" id=mover的div块切换样式.one" id="b4"/>
$("#b4").click(function(){
$("#mover").toggleClass("one");
}); //<input type="button" value=" hasClass:判断span元素是否有spanone样式" id="b5"/>
$("#b5").click(function(){
var result=$("span").first().hasClass("spanone");
alert(result);
});
</script>
</html>

CSS_CRUD.html

二、JQuery中的Ajax操作

  1.JQuery对Ajax操作进行了封装,第一层封装是$.ajax(),第二层封装是load(),$.get(),$.post(),第三层封装是$.getScript(),$.getJSON()。

  2.load()方法:载入远程HTML文件代码,并插入到DOM中。

    (1)调用形式:load(url,[data],[callback]);

    (2)参数说明:

        url:请求的网址

        data:浏览器请求的数据

        callback:回调函数,有三个参数:代表请求返回内容的data、代表请求状态的textStatus对象(其值可能是success/error/notmodify/timeout四种中的其中一种)以及XMLHttpRequest对象

    (3)使用细节:如果只想加载目标HTML中的其中一部分,则需要选择器进行筛选,使用方法:url空格selector;该方法若客户端有参数传递则使用POST方法请求,否则使用GET方式请求。

    (4)使用案例:

 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>ddd</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script language="JavaScript" src="../js/jquery-1.4.2.js">
</script>
<style type="text/css">
div, span {
width: 140px;
height: 140px;
margin: 20px;
background: #9999CC;
border: #000 1px solid;
float: left;
font-size: 17px;
font-family: Roman;
} div.mini {
width: 30px;
height: 30px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family: Roman;
} div.visible {
display: none;
}
</style>
<!--引入jquery的js库-->
</head>
<body>
<form action="" name="form1" id="form1">
<input type="text" name="username" id="username" value="zhang">
<br>
<input type="text" name="psw" id="psw" value="99999">
<br>
<input type="button" id="b1" value="登陆">
</form>
<div id="one">
</div>
</body>
<script type="text/javascript">
$("#b1").click(function(){
var username=$("#username").val();
var psw=$("#psw").val();
$("#one").load("./load01.jsp","username="+username+"&psw="+psw,function(data,textStatus,xmlHttpRequest){
alert(data);
alert(textStatus);
alert(xmlHttpRequest);
});
});
</script>
</html>

load01.html

 <%@ page language="java" pageEncoding="UTF-8"%>
<%
System.out.println("有新的请求消息!");
String username=request.getParameter("username");
String psw=request.getParameter("psw");
System.out.println("用户名:"+username);
System.out.println("密码:"+psw);
out.println("你好,客户端!");
%>

load01.jsp

      两个文件在同一个目录下。

    运行结果:

    【Java EE 学习 33 上】【JQuery样式操作】【JQuery中的Ajax操作】【JQuery中的XML操作】

    【Java EE 学习 33 上】【JQuery样式操作】【JQuery中的Ajax操作】【JQuery中的XML操作】

  3.$.get()方法:这是一个简单的GET请求功能以取代复杂的$.ajax,请求成功的时候调用回调函数,如果请求失败的时候需要调用函数则使用$.ajax

    (1)格式:jQuery.get(url,[data],[callback],[type]),返回值是XMLHttpRequest

        参数说明:url:请求的URL地址

              data:请求的参数,可以使用json格式的数据

              callback:回调函数,格式见load()

              type:返回内容格式,可能是[xml/html/script/json/text/_default]中的其中一种。

    (2)回调函数格式:function(data,textStatus),也就是说,回调函数只有两个参数,和上面的load方法中的四种参数不同。

    (3)案例:

 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>ddd</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script language="JavaScript" src="../js/jquery-1.4.2.js"></script>
<style type="text/css">
div,span{
width: 140px;
height: 140px;
margin: 20px;
background: #9999CC;
border: #000 1px solid;
float:left;
font-size: 17px;
font-family:Roman;
} div.mini{
width: 30px;
height: 30px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
} div.visible{
display:none;
}
</style>
<!--引入jquery的js库--> </head> <body>
<form action="" name="form1" id="form1">
<input type="text" name="username" id="username" value="zhang"><br>
<input type="text" name="psw" id="psw" value="99999"><br>
<input type="button" id="b1" value="登陆">
</form> <div id="one">
</div> </body>
<script type="text/javascript">
$("#b1").click(function(){
var username=$("#username").val();
var password=$("#psw").val();
var xmlHttpRequest=$.get("./get.jsp","username="+username+"&password="+password+"",function(data,textStatus){
alert(data);
alert(textStatus);
});
alert(xmlHttpRequest);
});
</script>
</html>

get.html

 <%@ page language="java" pageEncoding="UTF-8"%>
<%
System.out.println("有新的请求消息!");
String username=request.getParameter("username");
String password=request.getParameter("password");
System.out.println(request.getMethod());
System.out.println("用户名:"+username);
System.out.println("密码:"+password);
out.println("你好,客户端!");
%>

get.jsp

两个文件在同一个目录中

    【Java EE 学习 33 上】【JQuery样式操作】【JQuery中的Ajax操作】【JQuery中的XML操作】

    【Java EE 学习 33 上】【JQuery样式操作】【JQuery中的Ajax操作】【JQuery中的XML操作】

  4$.post()方法:用法和$.get方法完全相同,但是使用的请求方式是POST。

  5.序列化元素

    (1)简介:JQuery为准备“发送到服务器的key/value数据”,提供了一个简化的方法:serialize(),该方法用于一个JQuery对象,能将DOM元素内容序列化为字符串,用于Ajax请求。

    (2)使用方法:selector.serialize()。

    (3)使用serialize()方法可以自动完成对参数的url编码。

    (4)案例:对之前的GET请求方式稍作修改

 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>ddd</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script language="JavaScript" src="../js/jquery-1.4.2.js"></script>
<style type="text/css">
div,span{
width: 140px;
height: 140px;
margin: 20px;
background: #9999CC;
border: #000 1px solid;
float:left;
font-size: 17px;
font-family:Roman;
} div.mini{
width: 30px;
height: 30px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
} div.visible{
display:none;
}
</style>
<!--引入jquery的js库--> </head> <body>
<form action="" name="form1" id="form1">
<input type="text" name="username" id="username" value="zhang"><br>
<input type="text" name="psw" id="psw" value="99999"><br>
<input type="button" id="b1" value="登陆">
</form> <div id="one">
</div> </body>
<script type="text/javascript">
$("#b1").click(function(){
/* var username=$("#username").val();
var password=$("#psw").val(); */
var xmlHttpRequest=$.post("./get.jsp",$("#form1").serialize(),function(data,textStatus){
alert(data);
alert(textStatus);
});
alert(xmlHttpRequest);
});
</script>
</html>

Serialize_Demo.html

 <%@ page language="java" pageEncoding="UTF-8"%>
<%
System.out.println("有新的请求消息!");
String username=request.getParameter("username");
String password=request.getParameter("psw");
System.out.println(request.getMethod());
System.out.println("用户名:"+username);
System.out.println("密码:"+password);
out.println("你好,客户端!");
%>

get.jsp

    注意,这里已经换成了POST的请求方式。

    封装好的数据发送到服务器端的时候服务器使用表单中给的name属性获取表单中的值。

三、JQuery中的XML操作

  1.JQuery中可以使用$.get()或者$.post()方法来加载xml。

  2.JQuery解析XML和解析DOM一样同样可以使用find(),children(),等函数来解析和使用each()方法来进行遍历

  3.JQuery小练习:二级菜单联动

 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>test01.html</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script language="JavaScript" src="../js/jquery-1.4.2.js"></script>
</head>
<body>
<select id="province" name="province">
<option value="">请选择....</option>
</select>
<select id="city" name="city">
<option value="">请选择.....</option>
<option value="铁岭">铁岭</option>
</select>
</body>
<script type="text/javascript">
$().ready(function(){
//页面载入的时候加载第一级菜单
$.get("cities.xml",function(xml){
$xml=$(xml);
$children=$xml.find("province");
$children.each(function(index,domEle){
$city=$("<option></option>");
$city.val($(domEle).attr("name"));
$city.text($(domEle).attr("name"));
$("#province").append($city);
});
});
});
$("#province").change(function(){
$("#city option:gt(0)").remove();
$val=$("#province").val();
$.get("cities.xml",function(xml){
$xml=$(xml);
$children=$xml.find("province");
$children.each(function(index,domEle){
$province_name=$(domEle).attr("name");
if($val==$province_name){
//接下来遍历该省份中的city
$(domEle).children().each(function(index,cityDom){
var $city_name=$(cityDom).text();
var $city=$("<option></option>");
$city.val($city_name);
$city.text($city_name);
$("#city").append($city);
});
return;
}
});
});
});
</script>
</html>

city.html

 <?xml version="1.0" encoding="GB2312"?>
<china>
<province name="吉林省">
<city>长春</city>
<city>吉林市</city>
<city>四平</city>
<city>*</city>
<city>通化</city>
</province>
<province name="辽宁省">
<city>沈阳</city>
<city>大连</city>
<city>鞍山</city>
<city>抚顺</city>
<city>铁岭</city>
</province>
<province name="山东省">
<city>济南</city>
<city>青岛</city>
<city>威海</city>
<city>烟台</city>
<city>潍坊</city>
</province>
</china>

cities.xml

  运行结果:

    【Java EE 学习 33 上】【JQuery样式操作】【JQuery中的Ajax操作】【JQuery中的XML操作】【Java EE 学习 33 上】【JQuery样式操作】【JQuery中的Ajax操作】【JQuery中的XML操作】

  4.小知识点:使用remove方法删除select下的指定option选项。