【Java EE 学习 33 上】【JQuery样式操作】【JQuery中的Ajax操作】【JQuery中的XML操作】
一、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
两个文件在同一个目录下。
运行结果:
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
两个文件在同一个目录中
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
运行结果:
4.小知识点:使用remove方法删除select下的指定option选项。
【Java EE 学习 33 上】【JQuery样式操作】【JQuery中的Ajax操作】【JQuery中的XML操作】的更多相关文章
- 【Java EE 学习 32 上】【JQuery】【选择器】
一.JQuery简介 1.JQuery是JavaScript库,封装了很多预定义对象和实用函数. 2.JQury的优势: (1)简洁,其宗旨就是写更少的代码做更多的事. (2)文档声明非常全面:htt ...
- 【Java EE 学习 74 上】【数据采集系统第六天】【使用Jfreechart的统计图实现】【Jfreechart的基本使用方法】
之前已经实现了数据的采集,现在已经有了基本的数据,下一步就需要使用这些数据实现统计图的绘制了.这里使用Jfreechart实现这些统计图的绘制.首先看一下Jfreechart的基本用法,只有知道了它的 ...
- 【Java EE 学习 80 上】【WebService】
一.WebService概述 什么是WebService,顾名思义,就是基于Web的服务,它使用Http方式接收和响应外部系统的某种请求,从而实现远程调用.WebService实际上就是依据某些标准, ...
- 【Java EE 学习 79 上】【mybatis 基本使用方法】
一.简介 mybatis类似于hibernate,都是简化对数据库操作的框架,但是和hibernate不同的是,mybatis更加灵活,整体来说框架更小,这体现在它需要我们手写SQL语句,而hiber ...
- 【Java EE 学习 25 上】【网上图书商城项目实战】
一.概述 1.使用的jdk版本:1.6 2.java EE版本:1.6 3.指导老师:传智播客 王建 二.小项目已经实现的功能 普通用户: 1.登陆 2.注册 3.购物 4.浏览 管理员用户(全部管理 ...
- 【Java EE 学习 72 上】【数据采集系统第四天】【增加调查logo】【文件上传】【动态错误页指定】【上传限制】【国际化】
增加logo的技术点:文件上传,国际化 文件上传的功能在struts2中是使用文件上传拦截器完成的. 1.首先需要在页面上添加一个文件上传的超链接. 点击该超链接能够跳转到文件上传页面.我给该表单页面 ...
- 【Java EE 学习 49 上】【Spring学习第一天】【基本配置】
一.HelloWorld 需要的jar文件(以2.5.5为例):spring.jar,common-logging.jar 1.新建类com.kdyzm.spring.helloworld.Hello ...
- 【Java EE 学习 35 上】【strus2】【类型转换器】【struts2和Servlet API解耦】【国际化问题】【资源文件乱码问题已经解决】
一.类型转换器 1.在动作类action中,声明和表单中name属性的值同名的属性,提供get和set方法,struts2就可以通过反射机制,从页面中获取对应的内容 package com.kdyzm ...
- 【Java EE 学习 31】【JavaScript基础增强】【Ajax基础】【Json基础】
一.JavaScript基础增强 1.弹窗 (1)使用window对象的showModelDialog方法和showModelessDialog方法分别可以弹出模式窗口和非模式窗口,但是只能在IE中使 ...
随机推荐
- 大图居中,以1920px为例
<div style="overflow: hidden; position: relative;"> <img src="img.jpg" ...
- 关于XML序列化与CultureInfo
不同的计算机系统可能有着不同的CultureInfo,例如在中文环境下日期通常这样显示03/30/2016,而在有的操作系统下它可能是这样的30.3.2016. 这样的话带来一个问题,例如在中文环境下 ...
- Notepad++编写Markdown
Markdown语法高亮 下载userDefineLang_markdown.xml 打开Notepad++的 Language 菜单,选中底部的 Define your language... 在 ...
- Resharper的使用
一:Reshaper是什么 即便是那些整天攻击 .NET 和 C# 的人,也常常不得不承认 Visual Studio 确实是个够强大的 IDE,除非他认为更少的 IDE 功能和命令行调试才是更强大的 ...
- 10月28日上午 PHP数据访问
1.建一个连接(连接PHP和MYSQL) $db = new MySQLi("localhost","root","666","t ...
- js 常用函数收集(基础)
(1).判断是否为数值 function isNum(obj){ return !isNaN(parseFloat(obj)) && isFinite(obj); } (2).判断是否 ...
- 深入理解IoC/DI
------------------------------------------------------------------------ 理解IoC/DI 1.控制反转 --> 谁控制谁 ...
- 2、HTML 基础知识
一.HTT(PHyper Text Markup Language)即超文本语言. 特点: 1.通过标签来定义的语言,代码都是由标签所组成 2.不区分大小写 3.由<html>开始< ...
- tyvj1106 登山
背景 在很久很久以前,有一个动物村庄,那里是猪的乐园(^_^),村民们勤劳.勇敢.善良.团结…… 不过有一天,最小的小小猪生病了,而这种病是极其罕见的,因此大家都没有储存这种药物.所以晴 ...
- Ruby常用比较操作符
操作符 含义 == 测试值是否相等 ==== 用来比较case语句的目标和每个when从句的项 <=> 通用比较操作符. 根据接受者小于, 等于, 大于其参数, 返回-1, 0. 1 & ...