jQuery框架
jQuery 1.4 是企业主流版本,从jQuery1.6 开始引入大量新特性。最新版本 2.1.1,这里讲解以1.8.3为主(新版本主要是浏览器兼容问题以及新特性)
jQuery 提供 jquery-1.8.3.js 和 jquery-1.8.3.min.js
jquery-1.8.3.js jQuery框架源码,没有被精简,体积较大 (主要用来研究 jQuery源码),企业开发时,需要导入 jquery-1.8.3.min.js (精简过)
1.jQuery程序快速入门
window.onload = function() {...}
等价于$(document).ready(function(){...});
①:jQuery基本使用
传统Js写法:
代码语言:javascript复制<scripttype="text/javascript">
window.onload=function(){
alert("传统JS,Ok");
}
</script>
jQuery写法:
<scripttype="text/javascript"src="../jquery-1.8.3.min.js"></script>
<scripttype="text/javascript">
$(function(){
alert("ok");
});
$(document).ready(function(){
alert("OK");
});
</script>
②:jQuery核心函数
1)jQuery(callback) // 页面onload 函数
2)jQuery(expression, [context]) // 查找指定对象 ------ 九种选择器
3)jQuery(elements) // 将dom对象转换为jQuery对象
* document 是DOM对象 jQuery(document) 成为了jQuery对象
4)jQuery(html, [ownerDocument]) // 将html转换jQuery对象
* jQuery("<p>hello</p>") ----- 得到 jQuery对象
Demo:
代码语言:javascript复制<scripttype="text/javascript"src="../jquery-1.8.3.min.js"></script>
<script type="text/javascript">
$(function(){
// 获得div对象
var domObject = document.getElementById("mydiv"); // 获得DOM对象
domObject.innerHTML = "ITCAST";
// 通过包装DOM对象,成为jQuery对象
var $jQueryObject = $(domObject); // DOM对象成为 jQuery对象
$jQueryObject.html("传智播客"); // html()是jQuery对象的方法
// 通过访问jQuery对象下标0 元素,获得DOM对象
var dom1 = $jQueryObject[0]; // 转换jQuery对象为DOM对象
var dom2 = $jQueryObject.get(0);
dom2.innerHTML = "传智播客ITCAST";
});
</script>
<body>
<divid="mydiv">hello</div>
</body>
jQuery对象无法使用DOM对象属性方法,DOM对象也无法使用jQuery对象属性方法。但是我们可以使用jQuery提供方法,将DOM对象通过jQuery()函数包装成为jQuery对象,同样我们可以把jQuery对象转化成DOM对象。
jQuery--->DOM对象:$jQuery对象[0]或者$jQuery对象.get(0);
DOM对象--->jQuery:$(DOM对象)
2.jQuery九种选择器
选择器是jQuery 的根基, 在 jQuery 中, 对事件处理, 遍历 DOM 和 Ajax 操作都依赖于选择器
jQuery(expression, [context]) 在核心函数jQuery中传入表达式,对页面中元素进行选择======================jQuery核心函数第二种!
①:基本选择器
根据元素id属性、class属性、元素名称 对元素进行选择
id选择器: $("#元素id属性")
class选择器: $(".元素class属性")
元素名称选择器:$("元素名称")
多个选择器同时使用 selector1,select2 例如 : $("#xxid ,.xxxclass") 同时选择id 和 class匹配两类元素
练习1:
² 通过each() 在每个div元素内容前 加入 “传智播客”
² 通过size() / length 打印页面中 class属性为 itcast 的元素数量
² 通过index() 打印 id属性为foo 的div标签 是页面内的第几个div标签
代码语言:javascript复制<scripttype="text/javascript"src="../jquery-1.8.3.min.js"></script>
<scripttype="text/javascript">
$(function(){
// 选中所有div 得到集合
$("div").each(function(){
// 在每个div内容前加入“传智播客”
// this.innerHTML = "传智播客" this.innerHTML ;
$(this).html("传智播客" $(this).html());
});
// 通过size() / length 打印页面中 class属性为 itcast 的元素数量
// alert($(".itcast").size());
alert($(".itcast").length);
// 通过index() 打印 id属性为foo 的div标签 是页面内的第几个div标签
alert($("div").index($("#foo")));
});
</script>
<body>
<div>DIVAAAA</div>
<divclass="itcast">DIVBBBB</div>
<div>DIVCCCC</div>
<div>DIVDDDD</div>
<divclass="itcast">DIVEEEE</div>
<divid="foo">DIVFFFF</div>
<p>PAAAA</p>
<pclass="itcast">PBBBB</p>
<p>PCCCC</p>
</body>
②:层级选择器
根据祖先、后代、父子关系、兄弟关系 进行选择
ancestor descendant 获取ancestor元素下边的所有元素 $("form input")
parent > child 获取parent元素下边的所有直接child 子元素 $("form > input")
prev next 获取紧随pre元素的后一个兄弟元素 $("label input")
prev ~ siblings 获取pre元素后边的所有兄弟元素 $("form ~ input")
练习2:
² 将class属性值为itcast的元素下所有a元素字体变为红色
² 将class属性值为itcast的元素下直接a元素字体变为蓝色
² 将div元素后所有兄弟a元素,字体变为黄色,大小变为30px
代码语言:javascript复制<scripttype="text/javascript"src="../jquery-1.8.3.min.js"></script>
<scripttype="text/javascript">
$(function(){
// 将class属性值为itcast的元素下所有a元素字体变为红色
$(".itcast a").css("color","red");
// 将class属性值为itcast的元素下直接a元素字体变为蓝色
$(".itcast>a").css("color","blue");
// 将div元素后所有兄弟a元素,字体变为黄色,大小变为30px
$("div~a").css({color:'yellow','font-size':'30px'});
});
</script>
<body>
<divclass="itcast">
<a>div link</a>
<p>info
<a>p link</a>
</p>
</div>
<a>link</a>
<pclass="itcast">
<a>p link</a>
</p>
<a>link</a>
</body>
运行结果
③:基本过滤选择器
:first 选取第一个元素 $("tr:first")
:last 选取最后一个元素 $("tr:last")
:not(selector) 去除所有与给定选择器匹配的元素 $("input:not(:checked)")
:even 选取所有元素中偶数索引的元素,从 0 开始计数 $("tr:even") ----- 选取奇数元素
:odd 选取所有元素中奇数索引的元素 ,从0 开始计数 $("tr:odd") ------ 选取偶数元素
:eq(index) 选取指定索引的元素 $("tr:eq(1)")
:gt(index) 选取索引大于指定index的元素 $("tr:gt(0)")
:lt(index) 选取索引小于指定index的元素 $("tr:lt(2)")
:header 选取所有的标题元素 如:h1, h2, h3 $(":header")
:animated 匹配所有正在执行动画效果的元素
练习3:
² 设置表格第一行,显示为红色
² 设置表格除第一行以外 显示为蓝色
² 设置表格奇数行背景色 黄色
² 设置表格偶数行背景色 绿色
² 设置页面中所有标题 显示为灰色
² 设置页面中正在执行动画效果div背景黄色,不执行动画div背景绿色
代码语言:javascript复制<scripttype="text/javascript"src="../jquery-1.8.3.min.js"></script>
<scripttype="text/javascript">
$(function(){
// 设置表格第一行,显示为红色
$("tr:first").css("color","red");
// 设置表格除第一行以外 显示为蓝色
// $("tr:not(:first)").css("color","blue");
$("tr:gt(0)").css("color","blue");
// 设置表格奇数行背景色 黄色 /设置表格偶数行背景色 绿色
$("tr:even").css("background-color","yellow");
$("tr:odd").css("background-color","green");
// 设置页面中所有标题 显示为灰色
$(":header").css("color","gray");
// 设置页面中正在执行动画效果div背景黄色,不执行动画div背景绿色
// 无法选中正在执行动画的元素
$("div:not(:animated)").css("background-color","green");
$("div").click(function(){
$(this).css("background-color","yellow");//设置执行动画元素
$(this).slideUp("slow");
});
});
</script>
<body>
<h1>表格信息</h1>
<h2>这是一张商品表</h2>
<tableborder="1"width="600">
<tr>
<th>商品编号</th>
<th>商品名称</th>
<th>售价</th>
<th>数量</th>
</tr>
<tr>
<td>001</td>
<td>冰箱</td>
<td>3000</td>
<td>100</td>
</tr>
<tr>
<td>002</td>
<td>洗衣机</td>
<td>2000</td>
<td>50</td>
</tr>
<tr>
<td>003</td>
<td>热水器</td>
<td>1500</td>
<td>20</td>
</tr>
<tr>
<td>004</td>
<td>手机</td>
<td>2188</td>
<td>200</td>
</tr>
</table>
<div>
slideDown(speed, [callback])
概述
通过高度变化(向下增大)来动态地显示所有匹配的元素,在显示完成后可选地触发一个回调函数。
这个动画效果只调整元素的高度,可以使匹配的元素以“滑动”的方式显示出来。在jQuery 1.3中,上下的padding和margin也会有动画,效果更流畅。
参数
speedString,Number三种预定速度之一的字符串("slow", "normal", or "fast")或表示动画时长的毫秒数值(如:1000)
callback (可选)FunctionFunction在动画完成时执行的函数
</div>
<div>
fadeOut(speed, [callback])
概述
通过不透明度的变化来实现所有匹配元素的淡出效果,并在动画完成后可选地触发一个回调函数。
这个动画只调整元素的不透明度,也就是说所有匹配的元素的高度和宽度不会发生变化。
参数
speedString,Number三种预定速度之一的字符串("slow", "normal", or "fast")或表示动画时长的毫秒数值(如:1000)
callback (可选)Function在动画完成时执行的函数
</div>
</body>
④:内容过滤选择器
内容选择器是对子元素和文本内容的操作
:contains(text) 选取包含text文本内容的元素 $("div:contains('John')") 文本内容含有john 的所有div
:empty 选取不包含子元素或者文本节点的空元素 $("td:empty") td元素必须为空
:has(selector) 选取含有选择器所匹配的元素的元素 $("div:has(p)").addClass("test"); 含有p子元素的div
:parent 选取含有子元素或文本节点的元素 $("td:parent") 所有不为空td元素选中
练习4:
² 设置含有文本内容 ”传智播客” 的 div 的字体颜色为红色
² 设置没有子元素的div元素 文本内容 ”这是一个空DIV“
² 设置包含p元素 的 div 背景色为黄色
² 设置所有含有子元素的span字体为蓝色
代码语言:javascript复制<script type="text/javascript" src="../jquery-1.8.3.min.js"></script>
<script type="text/javascript">
$(function(){
// 设置含有文本内容 ”传智播客” 的 div 的字体颜色为红色
$("div:contains('传智播客')").css("color","red");
// 设置没有子元素的div元素 文本内容 ”这是一个空DIV“
$("div:empty").html('这是一个空DIV');
// 设置包含p元素 的 div 背景色为黄色
$("div:has(p)").css("background-color","yellow");
// 设置所有含有子元素的span字体为蓝色
$("span:parent").css("color","blue");
});
</script>
<body>
<div>今天是个晴天</div>
<div>明天要去传智播客学 java</div>
<div><span>JavaScript</span> 是网页开发中脚本技术</div>
<div>Ajax 是异步的 JavaScript和 XML</div>
<div><p>jQuery</p> 是 JavaScript一个 轻量级框架</div>
<div></div>
</body>
⑤:可见性过滤选择器
根据元素的可见与不可见状态来选取元素
:hidden 选取所有不可见元素 $("tr:hidden")
:visible 选取所有可见的元素 $("tr:visible")
练习5:
² 为表单中所有隐藏域 添加 class属性,值为itcast
² 设置table所有 可见 tr 背景色 黄色
² 设置table所有 隐藏tr 字体颜色为红色,显示出来 ,并输出tr中文本值
代码语言:javascript复制<script type="text/javascript" src="../jquery-1.8.3.min.js"></script>
<script type="text/javascript">
$(function(){
// 为表单中所有隐藏域 添加 class属性,值为itcast
$("input:hidden").addClass("itcast");
// 设置table所有 可见 tr 背景色 黄色
$("tr:visible").css("background-color","yellow");
// 设置table所有 隐藏tr 字体颜色为红色,显示出来 ,并输出tr中文本值
$("tr:hidden").each(function(){
alert($(this).text());
});
$("tr:hidden").css("color","red");
$("tr:hidden").css("display","block");
});
</script>
<body>
<form>
订单号 itcast-xxxx 金额 100元
<!-- 隐藏令牌号 -->
<input type="hidden" name="token"
value="12312-0xccx-zx-asd-21-asd-gdfgd" />
<input type="submit" value="确认支付" />
</form>
<table>
<tr style="display:none;">
<td>冰箱</td>
</tr>
<tr style="visibility:hidden;">
<td>洗衣机</td>
</tr>
<tr>
<td>热水器</td>
</tr>
</table>
</body>
⑥:属性过滤选择器
通过元素的属性来选取相应的元素
[attribute] 选取拥有此属性的元素 $("div[id]")
[attribute=value] 选取指定属性值为value的所有元素
[attribute !=value] 选取属性值不为value的所有元素
[attribute ^= value] 选取属性值以value开始的所有元素
[attribute $= value] 选取属性值以value结束的所有元素
[attribute *= value] 选取属性值包含value的所有元素
练习6:
² 设置所有含有id属性的div,字体颜色红色
² 设置所有class属性值 含有itcast元素背景色为黄色
² 对所有既有id又有class属性div元素,添加一个点击事件,打印div标签中内容
代码语言:javascript复制<script type="text/javascript" src="../jquery-1.8.3.min.js"></script>
<script type="text/javascript">
$(function(){
// 设置所有含有id属性的div,字体颜色红色
$("div[id]").css("color","red");
// 设置所有class属性值 含有itcast元素背景色为黄色
$("[class *= 'itcast']").css("background-color","yellow");
// 对所有既有id又有class属性div元素,添加一个点击事件,打印div标签中内容
$("div[id][class]").click(function(){
alert($(this).html());
});
});
</script>
<body>
<div>AAAA</div>
<div id="mydiv" class="itcast1">BBBB</div>
<div class="itcast2">CCCC</div>
<div id="mydiv2">DDDD</div>
<div class="divclass">EEEE</div>
<div id="xxx" class="itcast3">FFFF</div>
<p class="p-itcast">PPPPPP</p>
</body>
⑦:子元素过滤选择器
对某元素中的子元素进行选取
:nth-child(index/even/odd) 选取索引为index的元素、索引为偶数的元素、索引为奇数的元素 ----- index 从1开始 区别 eq
:first-child 选取第一个子元素
:last-child 选取最后一个子元素
:only-child 选取唯一子元素,它的父元素只有它这一个子元素
练习7:
² 选择id属性mytable 下3的倍数行,字体颜色为红色
² 表格 奇数行 背景色 黄色
² 表格 偶数行 背景色 灰色
² 只有一个td的 tr元素 字体为 蓝色
代码语言:javascript复制<scripttype="text/javascript"src="../jquery-1.8.3.min.js"></script>
<scripttype="text/javascript">
$(function(){
// 选择id属性mytable 下3的倍数行,字体颜色为红色
$("#mytable tr:nth-child(3n)").css("color","red");
// 表格 奇数行 背景色 黄色 / 表格 偶数行 背景色 灰色
$("table tr:nth-child(even)").css("background-color","gray");
// $("table tr:nth-child(odd)").css("background-color","yellow"); // 从1计数
$("tr:even").css("background-color","yellow");// 从0计数
// 只有一个td的 tr元素 字体为 蓝色
$("tr td:only-child").css("color","blue");
});
</script>
</head>
<body>
<tableborder="1"width="400"id="mytable">
<tr><td>1</td><td>冰箱</td></tr>
<tr><td>2</td><td>洗衣机</td></tr>
<tr><td>3</td><td>热水器</td></tr>
<tr><td>4</td><td>电饭锅</td></tr>
<tr><td>5</td><td>电磁炉</td></tr>
<tr><td>6</td><td>豆浆机</td></tr>
<tr><td>7</td><td>微波炉</td></tr>
<tr><td>8</td><td>电视</td></tr>
<tr><td>9</td><td>空调</td></tr>
<tr><td>10</td><td>收音机</td></tr>
<tr><td>11</td><td>排油烟机</td></tr>
<tr><td>12</td><td>加湿器</td></tr>
<tr><td>13 电暖气</td>加湿器</tr>
</table>
</body>
⑧:表单过滤选择器
选取表单元素的过滤选择器
:input 选取所有<input>、<textarea>、<select >和<button>元素
:text 选取所有的文本框元素
:password 选取所有的密码框元素
:radio 选取所有的单选框元素
:checkbox 选取所有的多选框元素
:submit 选取所有的提交按钮元素
:image 选取所有的图像按钮元素
:reset 选取所有重置按钮元素
:button 选取所有按钮元素
:file 选取所有文件上传域元素
:hidden 选取所有不可见元素
练习8:
² 对所有text框和password框,添加离焦事件,校验输入内容不能为空
² 对button 添加 点击事件,提交form表单
代码语言:javascript复制<script type="text/javascript" src="../jquery-1.8.3.min.js"></script>
<script type="text/javascript">
$(function(){
// 对所有text框和password框,添加离焦事件,校验输入内容不能为空
$(":text,:password").blur(function(){
// 获得表单元素内容 val()
var value = $(this).val(); // 获得value 属性
// 将输入内容 trim
if($.trim(value) == "" ){
alert("用户名和密码不能为空");
}
});
// 对button 添加 点击事件,提交form表单
$(":button").click(function(){
$("#myform").submit();
});
});
</script>
<body>
<form action="regist" method="post" id="myform">
用户名 <input type="text" name="username" /><br/>
密码 <input type="password" name="password" /><br/>
性别 <input type="radio" name="gender" value="男" />男
<input type="radio" name="gender" value="女"/><br/>
城市 <select name="city">
<option value="北京">北京</option>
<option value="上海">上海</option>
</select>
个人简介 <textarea rows="5" cols="60" name="introduce"></textarea>
<input type="button" value="提交"/>
</form>
</body>
⑨:表单对象属性过滤选择器
选取表单元素属性的过滤选择器
:enabled 选取所有可用元素
:disabled 选取所有不可用元素
:checked 选取所有被选中的元素,如单选框、复选框
:selected 选取所有被选中项元素,如下拉列表框、列表框